/* ============================================================
   HAMZIO — Products (index list + product detail)
   Depends on styles.css (shared design system + inner-page components).
   The DETAIL page additionally loads services.css to reuse detail
   components (detail-meta, deliverables, process, benefits, related).
   Dark · glassy · neon-cyber glow · input→output motif
   ============================================================ */

/* ============================================================
   PRODUCTS — "why we build" intro strip
   ============================================================ */
.prod-intro{ display:grid; grid-template-columns:1.3fr 1fr; gap:48px; align-items:center; margin-top:8px; }
.prod-intro .pi-aside{ display:flex; flex-direction:column; gap:14px; }
.prod-intro .pi-stat{ padding:22px 24px; border-radius:var(--radius); }
.prod-intro .pi-stat b{ font-family:var(--font-display); font-weight:600; font-size:1.7rem; letter-spacing:-0.02em; display:block;
  background:linear-gradient(180deg,#fff,var(--cyan)); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.prod-intro .pi-stat span{ font-family:var(--font-mono); font-size:0.7rem; color:var(--text-3); margin-top:8px; display:block; line-height:1.5; }

/* ============================================================
   PRODUCT TILES — app-window mockups
   ============================================================ */
.prod-page-grid{ display:grid; gap:22px; margin-top:34px; }
.prod-page-grid[data-layout="grid"]{ grid-template-columns:repeat(2,1fr); }
.prod-page-grid[data-layout="grid"].compact{ grid-template-columns:repeat(3,1fr); }
.prod-page-grid[data-layout="stack"]{ grid-template-columns:1fr; }

/* card shell */
.app-card{ display:flex; flex-direction:column; border-radius:var(--radius-lg); overflow:hidden; position:relative;
  transition:transform .42s var(--ease), border-color .4s, box-shadow .42s; }
.app-card.linked:hover{ transform:translateY(-5px); border-color:var(--border-2);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.07), 0 36px 70px -46px var(--glow-cyan); }
.app-card.placeholder{ opacity:0.78; }

/* ---- app/browser window chrome ---- */
.ac-window{ flex:none; border-bottom:1px solid var(--hairline); }
.acw-bar{ display:flex; align-items:center; gap:12px; padding:11px 14px; background:rgba(6,8,16,0.55);
  border-bottom:1px solid var(--hairline); }
.acw-dots{ display:flex; gap:6px; flex:none; }
.acw-dots i{ width:9px; height:9px; border-radius:50%; background:var(--border-2); }
.acw-dots i:nth-child(1){ background:rgba(255,99,99,0.55); }
.acw-dots i:nth-child(2){ background:rgba(255,199,99,0.55); }
.acw-dots i:nth-child(3){ background:rgba(99,220,150,0.55); }
.acw-url{ flex:1; display:inline-flex; align-items:center; gap:8px; justify-content:center;
  font-family:var(--font-mono); font-size:0.7rem; color:var(--text-3); letter-spacing:0.02em;
  padding:6px 14px; border-radius:999px; border:1px solid var(--hairline); background:var(--glass);
  max-width:60%; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.acw-url svg{ width:11px; height:11px; flex:none; opacity:0.7; }
.acw-ver{ flex:none; font-family:var(--font-mono); font-size:0.62rem; letter-spacing:0.06em; color:var(--text-2);
  padding:4px 9px; border-radius:7px; border:1px solid var(--border); background:var(--glass); }

/* ---- preview screen (striped + glow, holds wireframe) ---- */
.acw-screen{ position:relative; overflow:hidden; aspect-ratio:16/9;
  background:repeating-linear-gradient(135deg, rgba(255,255,255,0.04) 0 13px, rgba(255,255,255,0.015) 13px 26px); }
.acw-screen::after{ content:''; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(360px 220px at 20% 12%, rgba(var(--cyan-rgb),0.16), transparent 62%),
             radial-gradient(320px 230px at 90% 104%, rgba(var(--violet-rgb),0.15), transparent 60%); }
.app-card[data-accent="violet"] .acw-screen::after{
  background:radial-gradient(360px 220px at 20% 12%, rgba(var(--violet-rgb),0.16), transparent 62%),
             radial-gradient(320px 230px at 90% 104%, rgba(var(--cyan-rgb),0.13), transparent 60%); }

/* abstract UI wireframe (neutral stand-in for a real screenshot) */
.acw-wire{ position:absolute; inset:0; padding:18px; display:flex; flex-direction:column; gap:11px; z-index:1; }
.acw-wire .wb{ background:rgba(255,255,255,0.07); border-radius:6px; display:block; }
.acw-wire .wb-nav{ height:14px; width:62%; }
.acw-wire .wb-hero{ height:30%; min-height:46px; border-radius:9px;
  background:linear-gradient(120deg, rgba(var(--cyan-rgb),0.16), rgba(var(--violet-rgb),0.12)); border:1px solid var(--hairline); }
.acw-wire .wb-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:9px; flex:1; }
.acw-wire .wb-cards .wb{ height:100%; border:1px solid var(--hairline); background:rgba(255,255,255,0.045); }
.acw-wire .wb-lines{ display:flex; flex-direction:column; gap:7px; }
.acw-wire .wb-line{ height:8px; }
.acw-wire .wb-line.s{ width:46%; }
.acw-screen .ph-tag{ position:absolute; z-index:2; right:12px; bottom:12px;
  font-family:var(--font-mono); font-size:0.62rem; color:var(--text-3);
  border:1px dashed var(--border-2); padding:5px 10px; border-radius:8px; background:rgba(6,8,16,0.6);
  -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px); }

/* ---- card body ---- */
.ac-body{ padding:22px 24px 24px; display:flex; flex-direction:column; flex:1; }
.ac-head{ display:flex; align-items:center; justify-content:space-between; gap:14px; }

/* status chip */
.prod-status{ display:inline-flex; align-items:center; gap:7px; font-family:var(--font-mono); font-size:0.66rem;
  letter-spacing:0.08em; text-transform:uppercase; }
.prod-status .d{ width:7px; height:7px; border-radius:50%; }
.prod-status.live{ color:var(--mint); } .prod-status.live .d{ background:var(--mint); box-shadow:0 0 8px var(--mint); }
.prod-status.beta{ color:var(--cyan); } .prod-status.beta .d{ background:var(--cyan); box-shadow:0 0 8px var(--glow-cyan); }
.prod-status.dev{ color:var(--text-3); } .prod-status.dev .d{ background:var(--text-3); }

/* platform pills */
.ac-platforms{ display:flex; gap:6px; flex-wrap:wrap; }
.ac-platforms span{ font-family:var(--font-mono); font-size:0.6rem; letter-spacing:0.04em; color:var(--text-2);
  padding:4px 9px; border-radius:7px; border:1px solid var(--hairline); background:var(--glass); }

.ac-cat{ font-family:var(--font-mono); font-size:0.68rem; letter-spacing:0.1em; text-transform:uppercase;
  color:var(--cyan); margin-top:16px; }
.app-card[data-accent="violet"] .ac-cat{ color:var(--violet); }
.ac-body h3{ font-family:var(--font-display); font-weight:600; font-size:1.42rem; letter-spacing:-0.02em;
  line-height:1.2; margin-top:9px; transition:color .25s; }
.app-card.linked:hover .ac-body h3{ color:var(--cyan); }
.ac-body h3 .name-flag{ font-family:var(--font-mono); font-size:0.56rem; font-weight:400; letter-spacing:0.04em;
  color:var(--text-3); border:1px solid var(--hairline); border-radius:6px; padding:3px 7px; margin-left:8px;
  vertical-align:middle; text-transform:uppercase; white-space:nowrap; }
.ac-desc{ color:var(--text-2); font-size:0.95rem; line-height:1.55; margin-top:11px; }

/* feature bullets */
.ac-feats{ list-style:none; margin-top:16px; display:flex; flex-direction:column; gap:9px; }
.ac-feats li{ display:flex; align-items:flex-start; gap:10px; font-size:0.9rem; color:var(--text-2); line-height:1.45; }
.ac-feats li::before{ content:''; width:15px; height:15px; flex:none; margin-top:2px; border-radius:5px;
  background:rgba(var(--cyan-rgb),0.12); border:1px solid rgba(var(--cyan-rgb),0.32);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235cd6ff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12l4 4L19 7'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:center; background-size:10px; }
.app-card[data-accent="violet"] .ac-feats li::before{ background-color:rgba(var(--violet-rgb),0.12); border-color:rgba(var(--violet-rgb),0.32);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23a88bff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12l4 4L19 7'/%3E%3C/svg%3E"); }

/* footer row: price + link */
.ac-foot{ display:flex; align-items:center; justify-content:space-between; gap:16px;
  margin-top:auto; padding-top:20px; }
.ac-price{ font-family:var(--font-mono); font-size:0.7rem; color:var(--text-3); }
.ac-price b{ display:block; font-family:var(--font-display); font-size:1.1rem; font-weight:600; color:var(--text);
  margin-top:3px; letter-spacing:-0.01em; }
.ac-link{ display:inline-flex; align-items:center; gap:8px; font-weight:600; font-size:0.9rem; color:var(--cyan);
  white-space:nowrap; transition:gap .3s; }
.app-card.linked:hover .ac-link{ gap:12px; }
.ac-link.disabled{ color:var(--text-3); }

/* ---- STACK layout: window left, body right ---- */
.prod-page-grid[data-layout="stack"] .app-card{ flex-direction:row; align-items:stretch; }
.prod-page-grid[data-layout="stack"] .ac-window{ width:46%; min-width:300px; flex:none; border-bottom:none; border-right:1px solid var(--hairline);
  display:flex; flex-direction:column; }
.prod-page-grid[data-layout="stack"] .acw-screen{ flex:1; aspect-ratio:auto; min-height:200px; }
.prod-page-grid[data-layout="stack"] .ac-body{ padding:clamp(24px,3vw,38px); justify-content:center; }
.prod-page-grid[data-layout="stack"] .ac-body h3{ font-size:1.7rem; }
.prod-page-grid[data-layout="stack"] .ac-desc{ font-size:1rem; max-width:54ch; }

/* ---- COMPACT density ---- */
.prod-page-grid.compact{ gap:16px; }
.prod-page-grid.compact .acw-screen{ aspect-ratio:16/6; }
.prod-page-grid.compact .acw-wire{ padding:12px; gap:8px; }
.prod-page-grid.compact .acw-wire .wb-cards{ display:none; }
.prod-page-grid.compact .ac-feats{ display:none; }
.prod-page-grid.compact .ac-body{ padding:18px 20px 20px; }
.prod-page-grid.compact .ac-body h3{ font-size:1.22rem; }
.prod-page-grid.compact .ac-desc{ font-size:0.9rem; margin-top:9px; }
.prod-page-grid.compact .acw-screen .ph-tag{ display:none; }
.prod-page-grid[data-layout="stack"].compact .ac-window{ width:38%; min-width:240px; }
.prod-page-grid[data-layout="stack"].compact .acw-screen{ aspect-ratio:auto; }

/* ============================================================
   PRODUCT DETAIL — hero preview window (large)
   ============================================================ */
.product-hero-window{ margin-top:44px; border-radius:var(--radius-lg); overflow:hidden; }
.product-hero-window .acw-bar{ padding:13px 16px; }
.product-hero-window .acw-screen{ aspect-ratio:21/9; }
.product-hero-window .acw-wire{ padding:30px; gap:16px; }
.product-hero-window .acw-wire .wb-nav{ height:18px; }
.product-hero-window .acw-screen .ph-tag{ font-size:0.72rem; padding:8px 14px; right:16px; bottom:16px; }

/* product detail hero meta tweaks (reuses .detail-meta from services.css) */
.detail-hero .ph-inner .eyebrow .pill-live{ color:var(--mint); }

/* ============================================================
   PRICING PLANS (product detail)
   ============================================================ */
.plan-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:40px; align-items:stretch; }
.plan{ display:flex; flex-direction:column; padding:30px 28px; border-radius:var(--radius-lg); position:relative; }
.plan.featured{ border-color:rgba(var(--cyan-rgb),0.4); box-shadow:inset 0 1px 0 rgba(255,255,255,0.07), 0 30px 70px -50px var(--glow-cyan); }
.plan .plan-flag{ position:absolute; top:-11px; left:28px; font-family:var(--font-mono); font-size:0.6rem; letter-spacing:0.12em;
  text-transform:uppercase; color:#04111a; font-weight:600; padding:5px 11px; border-radius:999px;
  background:linear-gradient(180deg,var(--cyan),var(--cyan-2)); box-shadow:0 8px 22px -10px var(--glow-cyan); }
.plan .plan-name{ font-family:var(--font-display); font-weight:600; font-size:1.2rem; letter-spacing:-0.01em; }
.plan .plan-price{ font-family:var(--font-display); font-weight:600; font-size:2.2rem; letter-spacing:-0.03em; margin-top:14px; line-height:1; }
.plan .plan-price .per{ font-family:var(--font-mono); font-size:0.74rem; font-weight:400; color:var(--text-3); letter-spacing:0; }
.plan .plan-note{ font-family:var(--font-mono); font-size:0.68rem; color:var(--text-3); margin-top:10px; }
.plan .plan-feats{ list-style:none; margin-top:22px; display:flex; flex-direction:column; gap:11px; flex:1; }
.plan .plan-feats li{ display:flex; align-items:flex-start; gap:10px; font-size:0.92rem; color:var(--text-2); line-height:1.45; }
.plan .plan-feats li::before{ content:''; width:16px; height:16px; flex:none; margin-top:2px; border-radius:5px;
  background:rgba(var(--cyan-rgb),0.12); border:1px solid rgba(var(--cyan-rgb),0.32);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235cd6ff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12l4 4L19 7'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:center; background-size:11px; }
.plan .btn{ margin-top:24px; justify-content:center; }

/* ============================================================
   DETAIL FINAL CTA (mirrors services.css so the list page is
   self-contained when services.css is not loaded)
   ============================================================ */
.detail-cta{ position:relative; padding:clamp(36px,6vw,68px); border-radius:var(--radius-lg); overflow:hidden; text-align:center; margin:64px 0; }
.detail-cta::before{ content:''; position:absolute; inset:0; z-index:-1;
  background:radial-gradient(640px 320px at 50% 0%, rgba(var(--cyan-rgb),0.18), transparent 65%),
             radial-gradient(560px 320px at 82% 120%, rgba(var(--violet-rgb),0.16), transparent 65%); }
.detail-cta h2{ font-family:var(--font-display); font-weight:600; font-size:clamp(1.9rem,4vw,2.8rem); line-height:1.08; letter-spacing:-0.03em; max-width:20ch; margin:0 auto; }
.detail-cta p{ color:var(--text-2); font-size:1.05rem; margin:18px auto 0; max-width:52ch; }
.detail-cta .dc-actions{ display:flex; gap:14px; justify-content:center; margin-top:30px; flex-wrap:wrap; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:980px){
  .prod-intro{ grid-template-columns:1fr; gap:30px; }
  .prod-intro .pi-aside{ flex-direction:row; }
  .prod-intro .pi-stat{ flex:1; }
  .prod-page-grid[data-layout="grid"].compact{ grid-template-columns:repeat(2,1fr); }
  .plan-grid{ grid-template-columns:1fr; max-width:520px; }
  .plan.featured{ order:-1; }
}
@media (max-width:760px){
  .prod-page-grid[data-layout="grid"]{ grid-template-columns:1fr; }
  .prod-page-grid[data-layout="stack"] .app-card{ flex-direction:column; }
  .prod-page-grid[data-layout="stack"] .ac-window{ width:100%; min-width:0; border-right:none; border-bottom:1px solid var(--hairline); }
  .prod-page-grid[data-layout="stack"] .acw-screen{ aspect-ratio:16/9; min-height:0; }
}
@media (max-width:560px){
  .prod-page-grid[data-layout="grid"].compact{ grid-template-columns:1fr; }
  .prod-intro .pi-aside{ flex-direction:column; }
}
