/*
Theme Name: Creative Computer Lab Maxshop
Theme URI: https://creativecomputerlab.org/
Author: Perplexity
Description: Maxshop-inspired WooCommerce theme for Creative Computer Lab with teal/blue branding, product-first homepage, repairs and booking.
Version: 1.0.0
Text Domain: cclab-maxshop
*/

:root, [data-theme="light"] {
  --color-bg: #f4f7f8;
  --color-surface: #ffffff;
  --color-surface-2: #eef5f7;
  --color-surface-3: #e5eef1;
  --color-border: rgba(13, 35, 53, 0.12);
  --color-text: #0d2335;
  --color-text-muted: #5e7281;
  --color-primary: #0b8c95;
  --color-primary-dark: #066f76;
  --color-blue: #1567b3;
  --color-blue-dark: #0c4f8d;
  --color-accent: #d8f2f4;
  --shadow-sm: 0 10px 25px rgba(9, 38, 57, 0.06);
  --shadow-md: 0 20px 40px rgba(9, 38, 57, 0.08);
  --radius-sm: 10px;
  --radius-md: 16px;
  --radius-lg: 22px;
  --radius-full: 999px;
  --space-2: .5rem;
  --space-3: .75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;
  --content: 1280px;
}
*,:before,:after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,sans-serif;background:var(--color-bg);color:var(--color-text);line-height:1.6}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block;height:auto}
button,input,select,textarea{font:inherit}
.container{max-width:var(--content);margin:0 auto;padding:0 var(--space-4)}
.topbar{background:linear-gradient(90deg,var(--color-blue),var(--color-primary));color:#fff;font-size:.86rem}
.topbar-inner{display:flex;justify-content:space-between;gap:1rem;padding:.65rem 0;flex-wrap:wrap}
.site-header{background:var(--color-surface);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:40}
.header-main{display:grid;grid-template-columns:auto 1fr auto;gap:var(--space-5);align-items:center;padding:1rem 0}
.branding{display:flex;align-items:center;gap:.8rem;font-weight:800}
.brand-mark{width:44px;height:44px;border-radius:14px;background:linear-gradient(145deg,var(--color-primary),var(--color-blue));display:grid;place-items:center;color:#fff;box-shadow:var(--shadow-sm)}
.brand-lines strong{display:block;font-size:1.1rem;line-height:1.1}
.brand-lines span{display:block;font-size:.8rem;color:var(--color-text-muted)}
.header-search form{display:flex;align-items:center;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-full);overflow:hidden}
.header-search input{flex:1;border:0;background:transparent;padding:.95rem 1rem;min-width:180px}
.header-search button{border:0;background:var(--color-primary);color:#fff;padding:.95rem 1.2rem;cursor:pointer}
.header-actions{display:flex;align-items:center;gap:.75rem}
.header-action{padding:.8rem 1rem;border:1px solid var(--color-border);background:var(--color-surface);border-radius:var(--radius-full);font-weight:600}
.nav-wrap{background:var(--color-surface)}
.nav-inner{display:grid;grid-template-columns:260px 1fr auto;gap:var(--space-5);align-items:center;padding-bottom:1rem}
.cat-trigger{background:var(--color-text);color:#fff;border-radius:var(--radius-md);padding:1rem 1.1rem;font-weight:700;display:flex;justify-content:space-between;align-items:center}
.main-nav ul{display:flex;gap:1.1rem;list-style:none;padding:0;margin:0;flex-wrap:wrap}
.main-nav a{font-weight:600;color:var(--color-text-muted)}
.hero{padding:1rem 0 2rem}
.hero-grid{display:grid;grid-template-columns:260px 1.35fr .95fr;gap:var(--space-5);align-items:stretch}
.category-panel,.side-promo,.deal-card,.section-card,.product-card,.service-card,.repair-banner,.footer-panels>div{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}
.category-panel{padding:1rem}
.category-panel ul{list-style:none;padding:0;margin:0;display:grid;gap:.25rem}
.category-panel a{display:flex;justify-content:space-between;padding:.72rem .25rem;color:var(--color-text-muted);font-weight:600}
.hero-banner{position:relative;min-height:480px;border-radius:var(--radius-lg);overflow:hidden;background:linear-gradient(135deg,#e9f6f8,#f7fbfc);border:1px solid var(--color-border);box-shadow:var(--shadow-md)}
.hero-banner img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-overlay{position:relative;z-index:2;padding:2.4rem;max-width:54%}
.eyebrow{display:inline-flex;padding:.35rem .8rem;border-radius:var(--radius-full);background:rgba(255,255,255,.7);backdrop-filter:blur(8px);font-size:.76rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--color-blue)}
.hero-title{font-size:clamp(2rem,3vw,3.5rem);line-height:1.05;margin:1rem 0 .75rem}
.hero-copy{font-size:1rem;color:#28475c;max-width:30rem}
.hero-cta{display:flex;gap:.9rem;flex-wrap:wrap;margin-top:1.2rem}
.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-full);padding:.95rem 1.3rem;font-weight:700}
.btn-primary{background:var(--color-primary);color:#fff}
.btn-secondary{background:#fff;color:var(--color-text);border:1px solid var(--color-border)}
.hero-badges{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1rem}
.hero-badges span{background:#fff;border:1px solid var(--color-border);padding:.45rem .7rem;border-radius:var(--radius-full);font-size:.78rem;font-weight:700}
.side-promo{padding:1rem;display:grid;gap:1rem}
.side-promo img{border-radius:18px;aspect-ratio:1/1;object-fit:cover}
.side-promo .promo-block{padding:1rem;border-radius:18px;background:linear-gradient(135deg,var(--color-blue),var(--color-primary));color:#fff}
.section{padding:2rem 0}
.section-head{display:flex;justify-content:space-between;gap:1rem;align-items:end;margin-bottom:1rem;flex-wrap:wrap}
.section-head h2{margin:.35rem 0 0;font-size:1.7rem}
.section-head p{margin:0;color:var(--color-text-muted)}
.tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.tile{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.1rem;display:flex;gap:1rem;align-items:center}
.tile-icon{width:56px;height:56px;border-radius:18px;background:var(--color-accent);display:grid;place-items:center;color:var(--color-primary);font-weight:800}
.tile h3{margin:0 0 .2rem;font-size:1rem}
.tile p{margin:0;color:var(--color-text-muted);font-size:.9rem}
.showcase{display:grid;grid-template-columns:1.2fr .8fr;gap:1rem}
.showcase-banner{position:relative;min-height:300px;overflow:hidden;border-radius:var(--radius-lg);border:1px solid var(--color-border)}
.showcase-banner img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.showcase-content{position:relative;z-index:2;padding:2rem;max-width:58%}
.showcase-side{display:grid;gap:1rem}
.section-card{padding:1.2rem}
.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.product-card{overflow:hidden}
.product-image{background:var(--color-surface-2);aspect-ratio:1/1;display:block;overflow:hidden}
.product-image img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease}
.product-card:hover .product-image img{transform:scale(1.04)}
.product-body{padding:1rem}
.product-meta{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em}
.product-title{font-size:1rem;font-weight:700;margin:.35rem 0 .5rem;min-height:3em}
.price-row{display:flex;justify-content:space-between;align-items:center;gap:1rem}
.price-row .price{font-weight:800;color:var(--color-primary)}
.badge{display:inline-flex;padding:.35rem .65rem;background:var(--color-accent);color:var(--color-primary);border-radius:var(--radius-full);font-size:.74rem;font-weight:700}
.dual-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:1rem}
.service-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.service-card{padding:1.2rem}
.booking-form .field{margin-bottom:.9rem}
.booking-form label{display:block;font-size:.82rem;font-weight:700;margin-bottom:.35rem}
.booking-form input,.booking-form select,.booking-form textarea{width:100%;padding:.9rem 1rem;border-radius:14px;border:1px solid var(--color-border);background:#fff}
.footer{background:#0d2335;color:#d5dde3;margin-top:2rem}
.footer-panels{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:1rem;padding:2rem 0}
.footer-panels>div{background:rgba(255,255,255,.03);border-color:rgba(255,255,255,.08);box-shadow:none;padding:1.2rem}
.footer h3,.footer h4{color:#fff;margin-top:0}
.footer a{color:#d5dde3}
.footer-bottom{padding:1rem 0;border-top:1px solid rgba(255,255,255,.08);font-size:.86rem;color:#aebdca}
@media (max-width: 1180px){.hero-grid,.nav-inner,.showcase,.dual-grid{grid-template-columns:1fr}.tiles,.product-grid{grid-template-columns:repeat(2,1fr)}.hero-overlay,.showcase-content{max-width:100%}.category-panel{display:none}}
@media (max-width: 760px){.header-main{grid-template-columns:1fr}.nav-inner{grid-template-columns:1fr}.main-nav ul{gap:.7rem}.tiles,.product-grid,.service-grid,.footer-panels{grid-template-columns:1fr}.hero-banner{min-height:420px}.hero-overlay{padding:1.4rem}}


.category-panel-head{display:flex;align-items:center;justify-content:space-between;padding:18px 18px 8px;font-weight:700;color:var(--color-text)}
.category-panel-head button{width:38px;height:38px;border-radius:12px;background:#0d2335;color:#fff}
.hero-upgraded{padding-top:24px}
.hero-slider{position:relative;min-height:640px;border-radius:28px;overflow:hidden;background:#102638;box-shadow:var(--shadow-md)}
.hero-track{position:relative;height:100%}
.hero-slide{position:absolute;inset:0;opacity:0;pointer-events:none;transition:opacity .55s ease}
.hero-slide.is-active{opacity:1;pointer-events:auto}
.hero-slide img{width:100%;height:100%;object-fit:cover;filter:saturate(1.05) contrast(1.02)}
.hero-slide::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(7,22,33,.82) 0%,rgba(7,22,33,.58) 38%,rgba(7,22,33,.16) 100%)}
.hero-overlay{position:absolute;inset:auto auto 0 0;z-index:2;padding:34px;max-width:560px;color:#fff}
.hero-title{font-size:clamp(2.2rem,4vw,4rem);line-height:1.02;margin:16px 0 14px;max-width:12ch}
.hero-copy{color:rgba(255,255,255,.86);max-width:48ch}
.btn-secondary.light{background:rgba(255,255,255,.14);color:#fff;border-color:rgba(255,255,255,.3)}
.btn-secondary.light:hover{background:rgba(255,255,255,.22)}
.hero-badges span,.eyebrow.inverse{background:rgba(255,255,255,.14);color:#fff}
.slider-controls{position:absolute;left:26px;right:26px;bottom:26px;display:flex;align-items:center;justify-content:space-between;gap:18px;z-index:3}
.slider-arrow{width:48px;height:48px;border-radius:999px;background:rgba(255,255,255,.14);backdrop-filter:blur(14px);color:#fff;font-size:28px;line-height:1}
.slider-dots{display:flex;align-items:center;gap:10px}
.slider-dot{width:11px;height:11px;border-radius:999px;background:rgba(255,255,255,.35)}
.slider-dot.is-active{width:34px;background:#fff}
.side-stack{display:grid;grid-template-rows:1.2fr 1.2fr .8fr;gap:18px}
.mini-promo{border-radius:24px;padding:24px;display:flex;flex-direction:column;justify-content:space-between;min-height:170px;box-shadow:var(--shadow-sm)}
.mini-promo h3{font-size:1.35rem;line-height:1.15;max-width:14ch}
.mini-promo-dark{background:#102638;color:#fff}
.mini-promo-teal{background:linear-gradient(160deg,#0b8c95,#1567b3);color:#fff}
.mini-promo-light{background:var(--color-surface);border:1px solid var(--color-border)}
.text-link{display:inline-flex;align-items:center;gap:8px;color:#fff;font-weight:700;text-decoration:none}
.tiles-stronger .tile{align-items:flex-start}
.feature-band{padding-top:0}
.feature-band-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:18px}
.feature-callout{border-radius:24px;padding:28px;box-shadow:var(--shadow-sm)}
.feature-callout.dark{background:#0d2335;color:#fff}
.feature-callout.light{background:var(--color-surface);border:1px solid var(--color-border)}
.feature-callout h3{font-size:1.45rem;max-width:20ch;margin:10px 0}
.upgraded-showcase .showcase-banner{min-height:360px}
.booking-card{position:sticky;top:100px}
@media (max-width: 1100px){.hero-grid,.feature-band-grid{grid-template-columns:1fr}.side-stack{grid-template-columns:1fr 1fr 1fr;grid-template-rows:none}.category-panel{order:2}.hero-slider{order:1;min-height:560px}}
@media (max-width: 760px){.hero-upgraded{padding-top:12px}.category-panel{display:none}.hero-slider{min-height:520px}.hero-overlay{padding:22px}.hero-title{max-width:10ch}.slider-controls{left:18px;right:18px;bottom:18px}.side-stack{grid-template-columns:1fr}.mini-promo{min-height:auto}.feature-band-grid{grid-template-columns:1fr}.booking-card{position:static}}


.premium-hero{padding:26px 0 10px}
.premium-hero-grid{display:grid;grid-template-columns:280px 1fr;gap:20px;align-items:start}
.compact-panel{position:sticky;top:92px}
.hero-stage{display:grid;gap:20px}
.hero-feature-card{display:grid;grid-template-columns:1.02fr 1.18fr;gap:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:28px;overflow:hidden;box-shadow:var(--shadow-md);min-height:520px}
.hero-copy-wrap{padding:42px 38px;display:flex;flex-direction:column;justify-content:center}
.hero-copy-wrap h1{font-size:clamp(2.5rem,4.2vw,4.8rem);line-height:.96;letter-spacing:-.03em;max-width:10ch;margin:14px 0 18px}
.hero-copy-wrap p{font-size:1.02rem;color:var(--color-text-muted);max-width:46ch}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin:28px 0 18px}
.hero-metrics{display:flex;gap:10px;flex-wrap:wrap}
.hero-metrics span{padding:10px 14px;border-radius:999px;background:var(--color-surface-2);font-size:.82rem;font-weight:700;color:var(--color-text)}
.hero-visual-wrap{position:relative;min-height:520px;background:#dce8ee}
.hero-visual-wrap img{width:100%;height:100%;object-fit:cover}
.floating-product-note{position:absolute;left:24px;bottom:24px;background:rgba(255,255,255,.92);padding:14px 16px;border-radius:18px;max-width:230px;box-shadow:var(--shadow-sm)}
.floating-product-note small{display:block;font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:4px}
.hero-support-cards{display:grid;grid-template-columns:1.15fr .85fr;gap:20px}
.support-card{border-radius:24px;padding:28px;border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}
.support-card.dark{background:#0d2335;color:#fff;border-color:#0d2335}
.support-card.dark p{color:rgba(255,255,255,.78)}
.support-card.light{background:var(--color-surface)}
.support-card h3{font-size:1.55rem;line-height:1.05;max-width:18ch;margin:10px 0}
.teal-link{color:var(--color-primary)}
.premium-strip{padding-top:8px}
.premium-strip-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.premium-strip-grid article{background:var(--color-surface);border:1px solid var(--color-border);border-radius:22px;padding:20px 18px;box-shadow:var(--shadow-sm)}
.mini-label{display:block;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:10px}
.premium-strip-grid strong{display:block;font-size:1.06rem;margin-bottom:6px}
.premium-strip-grid p{font-size:.92rem;color:var(--color-text-muted)}
.premium-head{align-items:end}
.section-link{font-weight:700;color:var(--color-primary);text-decoration:none}
.premium-products .product-card-premium{border-radius:22px;overflow:hidden;border:1px solid rgba(10,35,53,.09);background:#fff;box-shadow:0 14px 30px rgba(9,38,57,.06)}
.premium-products .product-image{background:#f2f6f8}
.premium-products .product-body{padding:18px}
.premium-products .product-title a{font-size:1.06rem;color:var(--color-text);text-decoration:none}
.merchandising-band{padding-top:6px}
.merchandising-grid{display:grid;grid-template-columns:1.22fr .78fr;gap:20px}
.merch-card{position:relative;border-radius:28px;overflow:hidden;border:1px solid var(--color-border);background:var(--color-surface);box-shadow:var(--shadow-md)}
.merch-large{min-height:380px}
.merch-large img{width:100%;height:100%;object-fit:cover}
.merch-overlay{position:absolute;inset:auto auto 0 0;padding:30px;max-width:520px;color:#fff;background:linear-gradient(180deg,rgba(9,20,29,0) 0%,rgba(9,20,29,.86) 65%)}
.merch-overlay h2{font-size:clamp(1.8rem,2.8vw,3rem);line-height:1.02;max-width:14ch;margin:12px 0 18px}
.merch-stack{display:grid;gap:20px}
.merch-card.small{padding:28px;min-height:180px}
.light-card{background:var(--color-surface)}
.dark-card{background:#102638;color:#fff;border-color:#102638}
.dark-card p{color:rgba(255,255,255,.76)}
.merch-card h3{font-size:1.45rem;line-height:1.07;max-width:16ch;margin:10px 0}
.repair-zone{display:grid;grid-template-columns:1.1fr .9fr;gap:20px;align-items:start}
.align-start{align-items:start}
.compact-services .service-card{min-height:0}
.premium-booking{border-radius:24px;box-shadow:var(--shadow-md);top:96px}
@media (max-width:1100px){.premium-hero-grid,.repair-zone,.merchandising-grid,.hero-feature-card,.hero-support-cards,.premium-strip-grid{grid-template-columns:1fr}.compact-panel{position:relative;top:auto}.hero-visual-wrap{min-height:380px}}
@media (max-width:760px){.premium-hero{padding-top:14px}.premium-hero-grid{grid-template-columns:1fr}.compact-panel{display:none}.hero-copy-wrap{padding:26px 22px}.hero-copy-wrap h1{font-size:clamp(2rem,11vw,3.2rem)}.hero-actions{flex-direction:column;align-items:flex-start}.hero-visual-wrap,.hero-feature-card{min-height:auto}.hero-support-cards{grid-template-columns:1fr}.premium-strip-grid article,.support-card,.merch-card.small{padding:22px}.merch-overlay{padding:22px}.premium-booking{position:static}}


.product-card-premium{position:relative;transition:transform .22s ease, box-shadow .22s ease}
.product-card-premium:hover{transform:translateY(-4px);box-shadow:0 22px 34px rgba(9,38,57,.1)}
.product-card-premium .product-image img{aspect-ratio:1/1;object-fit:cover;width:100%;display:block}
.product-card-premium .product-meta{display:inline-flex;align-items:center;padding:7px 10px;border-radius:999px;background:var(--color-surface-2);font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:12px}
.product-card-premium .price-row{align-items:center}
.product-card-premium .badge{background:var(--color-accent);color:var(--color-primary);font-weight:700}
.product-card-premium .badge:hover{background:#c5edf0}
.support-card h3,.merch-card h3{letter-spacing:-.02em}
.hero-copy-wrap h1,.merch-overlay h2{letter-spacing:-.04em}


.enhanced-header{position:sticky;top:0;z-index:40;background:rgba(247,248,250,.88);backdrop-filter:blur(14px);border-bottom:1px solid rgba(12,29,48,.06)}
.premium-header-grid{display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center;padding:14px 0}
.premium-brand .brand-mark{width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,#0f8e9d,#0b2f4d);display:grid;place-items:center;color:#fff;font-weight:800}
.premium-search{display:flex;align-items:center;background:#fff;border:1px solid rgba(12,29,48,.08);border-radius:16px;overflow:hidden;box-shadow:0 10px 24px rgba(10,31,68,.05)}
.premium-search input{border:0;flex:1;padding:16px 18px;background:transparent}
.premium-search button{border:0;background:#0e9aa7;color:#fff;padding:16px 22px;font-weight:700}
.premium-actions{display:flex;align-items:center;gap:12px}
.premium-actions a{padding:11px 14px;border-radius:999px;color:#0b2239;font-weight:700}
.premium-actions .header-pill{background:#0e9aa7;color:#fff}
.cart-count{display:inline-grid;place-items:center;min-width:22px;height:22px;padding:0 6px;margin-left:8px;border-radius:999px;background:#e6f8fa;color:#0e7b86;font-size:.74rem;font-weight:800}
.shop-layout{display:grid;grid-template-columns:280px 1fr;gap:24px;align-items:start}
.shop-sidebar{position:sticky;top:112px}
.shop-sidebar h2{margin:6px 0 16px}
.sidebar-links{list-style:none;padding:0;margin:0 0 22px;display:grid;gap:10px}
.sidebar-links a{display:block;padding:11px 12px;border-radius:12px;background:#f5f8fb;color:#12314e;font-weight:600}
.sidebar-note{padding:16px;border-radius:16px;background:#082a47;color:#eaf6ff}
.archive-hero{margin-bottom:18px}
.archive-toolbar{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:16px}
.woocommerce ul.products{display:grid !important;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;list-style:none;padding:0;margin:0}
.archive-card{margin:0 !important}
.archive-thumb img{aspect-ratio:1/1;object-fit:cover;width:100%}
.single-layout{display:grid;grid-template-columns:1.05fr .95fr;gap:26px;align-items:start}
.single-gallery img{width:100%;border-radius:20px;aspect-ratio:4/3;object-fit:cover}
.single-summary h1{font-size:clamp(2rem,3vw,3.4rem);line-height:1.02;margin:10px 0 12px;letter-spacing:-.05em}
.single-price{font-size:1.7rem;font-weight:800;color:#0a8c98;margin-bottom:12px}
.single-copy{color:#4a647c;max-width:56ch}
.single-meta-strip{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0 20px}
.single-meta-strip span{padding:9px 12px;border-radius:999px;background:#eef6fb;color:#12314e;font-weight:700;font-size:.82rem}
.single-summary form.cart{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin:14px 0 22px}
.single-summary form.cart .qty{padding:12px;border-radius:12px;border:1px solid rgba(11,34,57,.12)}
.single-summary form.cart .single_add_to_cart_button{border:0;background:#0e9aa7 !important;color:#fff !important;border-radius:999px;padding:14px 22px;font-weight:800}
.single-support-note{padding:18px;border-radius:18px;background:#f5f8fb;border:1px solid rgba(11,34,57,.08)}
.single-support-note a{display:inline-block;margin-top:10px;color:#0e8c98;font-weight:700}
.single-detail-grid{display:grid;grid-template-columns:1fr 340px;gap:24px;margin-top:24px}
.single-promise{padding-left:18px;display:grid;gap:10px}
@media (max-width: 980px){.premium-header-grid,.shop-layout,.single-layout,.single-detail-grid{grid-template-columns:1fr}.shop-sidebar{position:static}.woocommerce ul.products{grid-template-columns:repeat(2,minmax(0,1fr))}.premium-actions{flex-wrap:wrap}}
@media (max-width: 640px){.woocommerce ul.products{grid-template-columns:1fr}.premium-search button{padding:14px 16px}.premium-actions{justify-content:flex-start}}


.site-footer{background:#0a2239;color:#d9e8f6;margin-top:56px;padding:48px 0 18px}
.site-footer a{color:#e8f6ff}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:22px;align-items:start}
.site-footer h3,.site-footer h4{color:#ffffff;margin:0 0 12px}
.site-footer p{color:#b8cadd;max-width:44ch}
.site-footer ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.site-footer li{color:#cfe0ee}
.copyright{margin-top:18px;padding-top:16px;border-top:1px solid rgba(255,255,255,.08);font-size:.88rem;color:#9fb5c9}
@media (max-width: 900px){.footer-grid{grid-template-columns:1fr 1fr}.site-footer{padding:36px 0 18px}}
@media (max-width: 560px){.footer-grid{grid-template-columns:1fr}}


.woocommerce-notices-wrapper,.woocommerce-breadcrumb,.woocommerce-message,.woocommerce-error,.woocommerce-info{max-width:1200px;margin:0 auto 16px;padding:0 16px}
.woocommerce-breadcrumb{padding-top:18px;color:#607a92;font-weight:600}
.woocommerce-breadcrumb a{color:#0d8f9b}
.woocommerce-message,.woocommerce-info,.woocommerce-error{list-style:none;background:#fff;border:1px solid rgba(11,34,57,.08);box-shadow:0 12px 28px rgba(11,34,57,.05);border-radius:16px;padding:16px 18px;color:#16324b}
.woocommerce-error{border-color:rgba(176,46,46,.18);background:#fff7f7}
.woocommerce-cart .entry-content,.woocommerce-checkout .entry-content,.woocommerce-account .entry-content{max-width:1200px;margin:0 auto;padding:24px 16px 48px}
.woocommerce-cart-form,.cart-collaterals,.woocommerce-checkout-review-order,.woocommerce-billing-fields,.woocommerce-additional-fields,.woocommerce-account .woocommerce,.woocommerce form.checkout{background:transparent}
.woocommerce table.shop_table{border:0 !important;border-radius:20px;overflow:hidden;background:#fff;box-shadow:0 18px 34px rgba(11,34,57,.06)}
.woocommerce table.shop_table th,.woocommerce table.shop_table td{padding:18px 16px;border-color:rgba(11,34,57,.06)}
.woocommerce-cart-form .product-thumbnail img{width:88px;border-radius:14px}
.woocommerce .cart_totals,.woocommerce .checkout .col2-set,.woocommerce-checkout-review-order{background:#fff;border:1px solid rgba(11,34,57,.07);border-radius:22px;padding:22px;box-shadow:0 18px 34px rgba(11,34,57,.05)}
.woocommerce .cart_totals h2,#order_review_heading,.woocommerce-checkout .col2-set h3,.woocommerce-account .addresses h2,.woocommerce-account .woocommerce-MyAccount-content h2{font-size:1.4rem;letter-spacing:-.03em;color:#0f2740;margin-bottom:16px}
.wc-proceed-to-checkout .checkout-button,.woocommerce #payment #place_order,.woocommerce button.button,.woocommerce a.button,.woocommerce button.button.alt,.woocommerce input.button.alt{background:#0e9aa7 !important;color:#fff !important;border-radius:999px !important;padding:14px 22px !important;font-weight:800 !important;border:0 !important;box-shadow:none !important}
.woocommerce a.button:hover,.woocommerce button.button:hover,.wc-proceed-to-checkout .checkout-button:hover{background:#0b7d87 !important}
.woocommerce .coupon{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.woocommerce .coupon #coupon_code{min-width:220px;border-radius:14px;border:1px solid rgba(11,34,57,.12);padding:13px 14px}
.woocommerce form .form-row input.input-text,.woocommerce form .form-row textarea,.woocommerce form .form-row select{border-radius:14px;border:1px solid rgba(11,34,57,.12);padding:14px 14px;background:#fff}
.woocommerce form .form-row label{font-weight:700;color:#17324c;margin-bottom:8px}
.woocommerce-checkout .col2-set{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-bottom:24px}
.woocommerce-checkout-review-order-table tfoot th,.woocommerce-checkout-review-order-table tfoot td{font-weight:800}
.woocommerce #payment{background:#f5f8fb;border-radius:18px;padding:14px 16px}
.woocommerce #payment div.payment_box{background:#fff;border-radius:14px}
.woocommerce-account .woocommerce{display:grid;grid-template-columns:260px 1fr;gap:24px}
.woocommerce-account .woocommerce-MyAccount-navigation ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.woocommerce-account .woocommerce-MyAccount-navigation a{display:block;padding:14px 16px;border-radius:14px;background:#fff;color:#16324b;font-weight:700;box-shadow:0 12px 28px rgba(11,34,57,.05)}
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a{background:#0c2947;color:#fff}
.woocommerce-account .woocommerce-MyAccount-content{background:#fff;border-radius:22px;padding:24px;box-shadow:0 18px 34px rgba(11,34,57,.06)}
.woocommerce-account .addresses .title .edit,.woocommerce-MyAccount-content a{color:#0d8f9b;font-weight:700}
.woocommerce-account .woocommerce-Address,.woocommerce-account .woocommerce-orders-table,.woocommerce-account .woocommerce-table{background:#f8fbfd;border-radius:18px;padding:18px}
@media (max-width: 980px){.woocommerce-checkout .col2-set,.woocommerce-account .woocommerce{grid-template-columns:1fr}}


.account-link{position:relative}
.account-link::before{content:'•';display:inline-block;margin-right:6px;color:#0e9aa7}
.account-entry-strip{padding-top:0}
.account-entry-card{display:flex;justify-content:space-between;gap:20px;align-items:center;background:#ffffff;border:1px solid rgba(11,34,57,.08);box-shadow:0 18px 34px rgba(11,34,57,.05);border-radius:24px;padding:26px 28px}
.account-entry-card h2{margin:6px 0 10px;font-size:clamp(1.35rem,2.2vw,2rem);letter-spacing:-.03em;color:#102841}
.account-entry-card p{color:#567089;max-width:60ch}
.account-entry-actions{display:flex;gap:12px;flex-wrap:wrap}
@media (max-width: 860px){.account-entry-card{flex-direction:column;align-items:flex-start}}

/* ===== Creative Computer Lab Shop Upgrade ===== */

.woocommerce-page .site-main,
.woocommerce .site-main {
  width: 100%;
  max-width: 1320px;
  margin: 0 auto;
  padding: 30px 20px 70px;
}

.ccl-shop-header {
  margin: 10px 0 30px;
  padding: 36px 32px;
  border-radius: 18px;
  background: linear-gradient(135deg, #0d1b2a 0%, #1b263b 100%);
  color: #fff;
}

.ccl-shop-eyebrow {
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  opacity: 0.8;
  margin-bottom: 10px;
}

.ccl-shop-title {
  font-size: 38px;
  line-height: 1.15;
  margin: 0 0 10px;
  color: #fff;
}

.ccl-shop-subtitle {
  max-width: 760px;
  font-size: 16px;
  line-height: 1.7;
  color: rgba(255,255,255,0.88);
  margin: 0;
}

.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering {
  margin-bottom: 24px;
}

.woocommerce ul.products {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 28px;
  margin: 0;
  padding: 0;
}

.woocommerce ul.products li.product {
  width: 100% !important;
  margin: 0 !important;
  float: none !important;
  list-style: none;
  background: #fff;
  border: 1px solid #e8edf3;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.05);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  padding-bottom: 18px;
}

.woocommerce ul.products li.product:hover {
  transform: translateY(-6px);
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.12);
}

.woocommerce ul.products li.product a img {
  width: 100%;
  height: 240px;
  object-fit: cover;
  margin: 0 0 16px;
  background: #f4f7fb;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-size: 18px;
  line-height: 1.45;
  padding: 0 18px;
  margin-bottom: 10px;
  color: #14213d;
}

.woocommerce ul.products li.product .price {
  display: block;
  padding: 0 18px;
  margin-bottom: 14px;
  color: #0f766e;
  font-size: 18px;
  font-weight: 700;
}

.woocommerce ul.products li.product .button {
  margin: 0 18px;
  display: inline-block;
  background: #0f172a;
  color: #fff;
  border-radius: 999px;
  padding: 12px 18px;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
}

.woocommerce ul.products li.product .button:hover {
  background: #2563eb;
  color: #fff;
}

.woocommerce span.onsale {
  top: 14px;
  left: 14px;
  right: auto;
  min-height: auto;
  min-width: auto;
  line-height: 1;
  padding: 8px 12px;
  border-radius: 999px;
  background: #dc2626;
  font-size: 12px;
  font-weight: 700;
}

@media (max-width: 1024px) {
  .woocommerce ul.products {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .ccl-shop-header {
    padding: 24px 20px;
  }

  .ccl-shop-title {
    font-size: 28px;
  }

  .woocommerce ul.products {
    grid-template-columns: 1fr;
  }

  .woocommerce ul.products li.product a img {
    height: 220px;
  }
}

.single-product .woocommerce-product-gallery {
  display: block;
}

.single-product .woocommerce-product-gallery .flex-control-thumbs {
  display: flex !important;
  gap: 10px;
  margin-top: 14px;
  padding: 0;
  list-style: none;
  flex-wrap: wrap;
}

.single-product .woocommerce-product-gallery .flex-control-thumbs li {
  width: 70px !important;
  list-style: none;
  margin: 0 !important;
}

.single-product .woocommerce-product-gallery .flex-control-thumbs img {
  border-radius: 10px;
  border: 1px solid #dbe3ea;
  cursor: pointer;
  opacity: 1 !important;
}

/* ===== Custom single product gallery ===== */

.premium-hero-clean .hero-feature-card-clean {
  min-height: 540px;
}

.empty-featured-state {
  text-align: left;
  padding: 32px;
}

.empty-featured-state h3 {
  margin: 10px 0 10px;
  font-size: 28px;
  color: #102841;
}

.empty-featured-state p {
  max-width: 56ch;
  color: #5a7187;
  margin-bottom: 18px;
}

.category-panel ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.category-panel ul li {
  border-bottom: 1px solid rgba(148, 163, 184, 0.18);
}

.category-panel ul li:last-child {
  border-bottom: 0;
}

.category-panel ul li a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 10px 0;
  text-decoration: none;
}

.category-panel ul li a span {
  font-size: 18px;
  opacity: 0.65;
}

.premium-hero-clean .hero-feature-card-clean {
  min-height: 540px;
}

.empty-featured-state {
  text-align: left;
  padding: 32px;
}

.empty-featured-state h3 {
  margin: 10px 0 10px;
  font-size: 28px;
  color: #102841;
}

.empty-featured-state p {
  max-width: 56ch;
  color: #5a7187;
  margin-bottom: 18px;
}

.category-panel ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.category-panel ul li {
  border-bottom: 1px solid rgba(148, 163, 184, 0.18);
}

.category-panel ul li:last-child {
  border-bottom: 0;
}

.category-panel ul li a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 10px 0;
  text-decoration: none;
}

.category-panel ul li a span {
  font-size: 18px;
  opacity: 0.65;
}

.premium-hero-clean .hero-feature-card-clean {
  min-height: 540px;
}

.empty-featured-state {
  text-align: left;
  padding: 32px;
}

.empty-featured-state h3 {
  margin: 10px 0 10px;
  font-size: 28px;
  color: #102841;
}

.empty-featured-state p {
  max-width: 56ch;
  color: #5a7187;
  margin-bottom: 18px;
}

.premium-strip-grid article strong a {
  color: inherit;
  text-decoration: none;
}

.best-seller-grid {
  margin-top: 10px;
}

.premium-actions a.is-active {
  color: #0f766e;
  font-weight: 700;
}

.best-seller-head {
  align-items: center;
}

.carousel-controls {
  display: flex;
  align-items: center;
  gap: 10px;
}

.carousel-btn {
  width: 44px;
  height: 44px;
  border: 1px solid #d7dee7;
  border-radius: 999px;
  background: #ffffff;
  color: #102841;
  font-size: 24px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.2s ease;
}

.carousel-btn:hover {
  background: #0f766e;
  border-color: #0f766e;
  color: #ffffff;
}

.product-carousel-wrap {
  position: relative;
}

.product-carousel-track {
  display: flex;
  gap: 24px;
  overflow-x: auto;
  padding: 4px 2px 14px;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scrollbar-width: thin;
}

.product-carousel-track::-webkit-scrollbar {
  height: 8px;
}

.product-carousel-track::-webkit-scrollbar-thumb {
  background: rgba(15, 118, 110, 0.35);
  border-radius: 999px;
}

.carousel-product-card {
  flex: 0 0 calc(25% - 18px);
  min-width: calc(25% - 18px);
  scroll-snap-align: start;
}

@media (max-width: 1100px) {
  .carousel-product-card {
    flex: 0 0 calc(50% - 12px);
    min-width: calc(50% - 12px);
  }
}

@media (max-width: 640px) {
  .carousel-controls {
    gap: 8px;
  }

  .carousel-btn {
    width: 40px;
    height: 40px;
  }

  .carousel-product-card {
    flex: 0 0 100%;
    min-width: 100%;
  }
}

.ccl-product-gallery {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.ccl-product-gallery-main img {
  width: 100%;
  display: block;
  border-radius: 20px;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  background: #f8fafc;
}

.ccl-product-gallery-thumbs {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.ccl-gallery-thumb {
  width: 78px;
  height: 78px;
  padding: 0;
  border: 1px solid #dbe3ea;
  border-radius: 12px;
  background: #fff;
  overflow: hidden;
  cursor: pointer;
  box-shadow: 0 4px 12px rgba(9, 38, 57, 0.06);
}

.ccl-gallery-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.ccl-gallery-thumb.is-active {
  border-color: #0e9aa7;
  box-shadow: 0 0 0 2px rgba(14, 154, 167, 0.14);
}

@media (max-width: 640px) {
  .ccl-gallery-thumb {
    width: 64px;
    height: 64px;
  }
}

.category-panel ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.category-panel ul li {
  border-bottom: 1px solid rgba(148, 163, 184, 0.18);
}

.category-panel ul li:last-child {
  border-bottom: 0;
}

.category-panel ul li a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 10px 0;
  text-decoration: none;
}

.category-panel ul li a span {
  font-size: 18px;
  opacity: 0.65;
}

.premium-hero-clean .hero-feature-card-clean {
  min-height: 540px;
}

.empty-featured-state {
  text-align: left;
  padding: 32px;
}

.empty-featured-state h3 {
  margin: 10px 0 10px;
  font-size: 28px;
  color: #102841;
}

.empty-featured-state p {
  max-width: 56ch;
  color: #5a7187;
  margin-bottom: 18px;
}

.premium-strip-grid article strong a {
  color: inherit;
  text-decoration: none;
}

.best-seller-head {
  align-items: center;
}

.carousel-controls {
  display: flex;
  align-items: center;
  gap: 10px;
}

.carousel-btn {
  width: 44px;
  height: 44px;
  border: 1px solid #d7dee7;
  border-radius: 999px;
  background: #ffffff;
  color: #102841;
  font-size: 24px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.2s ease;
}

.carousel-btn:hover {
  background: #0f766e;
  border-color: #0f766e;
  color: #ffffff;
}

.product-carousel-wrap {
  position: relative;
}

.product-carousel-track {
  display: flex;
  gap: 24px;
  overflow-x: auto;
  padding: 4px 2px 14px;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scrollbar-width: thin;
}

.product-carousel-track::-webkit-scrollbar {
  height: 8px;
}

.product-carousel-track::-webkit-scrollbar-thumb {
  background: rgba(15, 118, 110, 0.35);
  border-radius: 999px;
}

.carousel-product-card {
  flex: 0 0 calc(25% - 18px);
  min-width: calc(25% - 18px);
  scroll-snap-align: start;
}

@media (max-width: 1100px) {
  .carousel-product-card {
    flex: 0 0 calc(50% - 12px);
    min-width: calc(50% - 12px);
  }
}

@media (max-width: 640px) {
  .carousel-controls {
    gap: 8px;
  }

  .carousel-btn {
    width: 40px;
    height: 40px;
  }

  .carousel-product-card {
    flex: 0 0 100%;
    min-width: 100%;
  }
}

.ccl-product-gallery-main {
  border: 0;
  background: transparent;
  padding: 0;
  width: 100%;
  display: block;
  cursor: zoom-in;
}

.ccl-product-gallery-main img {
  width: 100%;
  display: block;
}

.ccl-lightbox {
  position: fixed;
  inset: 0;
  display: none;
  z-index: 9999;
}

.ccl-lightbox.is-open {
  display: block;
}

.ccl-lightbox-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(7, 15, 25, 0.82);
}

.ccl-lightbox-dialog {
  position: relative;
  z-index: 2;
  width: min(92vw, 1100px);
  max-height: 92vh;
  margin: 4vh auto;
  display: flex;
  align-items: center;
  justify-content: center;
}

.ccl-lightbox-dialog img {
  width: auto;
  max-width: 100%;
  max-height: 88vh;
  border-radius: 16px;
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.35);
  background: #fff;
}

.ccl-lightbox-close {
  position: absolute;
  top: -16px;
  right: -8px;
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 0;
  background: #ffffff;
  color: #102841;
  font-size: 28px;
  line-height: 1;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.18);
  cursor: pointer;
}

body.ccl-lightbox-open {
  overflow: hidden;
}

.ccl-lightbox-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 52px;
  height: 52px;
  border-radius: 999px;
  border: 0;
  background: rgba(255, 255, 255, 0.94);
  color: #102841;
  font-size: 32px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 3;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.18);
}

.ccl-lightbox-nav.prev {
  left: 18px;
}

.ccl-lightbox-nav.next {
  right: 18px;
}

.ccl-lightbox-counter {
  position: absolute;
  left: 50%;
  bottom: -18px;
  transform: translateX(-50%);
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(16, 40, 65, 0.9);
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  z-index: 3;
}

@media (max-width: 768px) {
  .ccl-lightbox-nav {
    width: 44px;
    height: 44px;
    font-size: 26px;
  }

  .ccl-lightbox-nav.prev {
    left: 10px;
  }

  .ccl-lightbox-nav.next {
    right: 10px;
  }

  .ccl-lightbox-counter {
    bottom: -10px;
    font-size: 13px;
  }
}

.single-overview,
.single-specs {
  margin: 20px 0 0;
  padding-top: 18px;
  border-top: 1px solid #e6edf5;
}

.single-overview h3,
.single-specs h3 {
  margin: 0 0 12px;
  font-size: 18px;
  color: #102841;
}

.single-overview p {
  margin: 0;
  color: #4f6478;
  line-height: 1.75;
}

.single-specs-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.spec-item {
  padding: 14px 16px;
  border: 1px solid #e6edf5;
  border-radius: 14px;
  background: #f8fbfe;
}

.spec-label {
  display: block;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #6b7f92;
  margin-bottom: 6px;
}

.spec-value {
  display: block;
  font-size: 15px;
  font-weight: 600;
  color: #102841;
}

.single-product-content {
  color: #4f6478;
  line-height: 1.8;
}

.single-product-content > *:first-child {
  margin-top: 0;
}

.single-product-content ul,
.single-product-content ol {
  padding-left: 18px;
}

.single-related {
  margin-top: 34px;
}

.related-products-grid {
  margin-top: 18px;
}

@media (max-width: 640px) {
  .single-specs-grid {
    grid-template-columns: 1fr;
  }
}

/* ===== MOBILE POLISH PATCH: paste under existing CSS ===== */

@media (max-width: 760px) {
  /* Keep sticky header useful but smaller on mobile */
  .site-header {
    top: 0;
    z-index: 60;
  }

  .topbar {
    display: none;
  }

  .header-main {
    grid-template-columns: 1fr auto;
    gap: .75rem;
    padding: .7rem 0;
  }

  .branding {
    min-width: 0;
    gap: .65rem;
  }

  .brand-mark {
    width: 38px;
    height: 38px;
    border-radius: 12px;
  }

  .brand-lines strong {
    font-size: .98rem;
  }

  .brand-lines span {
    font-size: .73rem;
  }

  .header-search {
    grid-column: 1 / -1;
    order: 3;
  }

  .header-search form {
    min-height: 48px;
  }

  .header-search input {
    padding: .82rem .95rem;
    min-width: 0;
    font-size: 16px; /* prevents iOS zoom */
  }

  .header-search button {
    padding: .82rem 1rem;
    white-space: nowrap;
  }

  .header-actions {
    gap: .45rem;
  }

  .header-action {
    padding: .7rem .8rem;
    font-size: .84rem;
  }

  .nav-wrap {
    display: none;
  }

  /* Hero spacing and copy */
  .premium-hero {
    padding: 10px 0 6px;
  }

  .hero-stage {
    gap: 14px;
  }

  .hero-feature-card {
    border-radius: 22px;
    overflow: hidden;
  }

  .hero-copy-wrap {
    padding: 22px 18px;
  }

  .hero-copy-wrap h1 {
    line-height: 1.02;
    letter-spacing: -.025em;
    margin: 10px 0 12px;
    max-width: 12ch;
  }

  .hero-copy-wrap p {
    font-size: .95rem;
    line-height: 1.55;
  }

  .hero-actions {
    width: 100%;
    gap: 10px;
    margin: 18px 0 14px;
  }

  .hero-actions .btn {
    width: 100%;
    min-height: 48px;
  }

  .hero-metrics {
    gap: 8px;
  }

  .hero-metrics span {
    padding: 8px 12px;
    font-size: .74rem;
  }

  .hero-visual-wrap {
    min-height: 260px;
  }

  .floating-product-note {
    left: 14px;
    right: 14px;
    bottom: 14px;
    max-width: none;
    padding: 12px 13px;
    border-radius: 14px;
  }

  .support-card h3,
  .merch-card h3 {
    font-size: 1.2rem;
    max-width: none;
  }

  /* Tighten section rhythm */
  .section {
    padding: 1.25rem 0;
  }

  .section-head,
  .premium-head,
  .best-seller-head {
    align-items: flex-start;
    margin-bottom: .85rem;
  }

  .section-head h2 {
    font-size: 1.35rem;
  }

  .section-link {
    font-size: .92rem;
  }

  /* Product cards */
  .product-grid {
    gap: .85rem;
  }

  .premium-products .product-body,
  .product-body {
    padding: 14px;
  }

  .product-card-premium .product-meta,
  .product-meta {
    display: block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: .68rem;
    margin-bottom: 8px;
  }

  .product-title,
  .premium-products .product-title a {
    font-size: .95rem;
    line-height: 1.35;
  }

  .product-card-premium .product-title {
    min-height: 2.7em;
  }

  .price-row {
    align-items: center;
    gap: .65rem;
  }

  .price-row .price {
    font-size: .96rem;
    line-height: 1.2;
  }

  .badge {
    padding: .42rem .62rem;
    font-size: .7rem;
    flex-shrink: 0;
  }

  /* Carousel usability on mobile */
  .carousel-controls {
    width: 100%;
    justify-content: flex-start;
    gap: 10px;
  }

  .carousel-btn {
    width: 42px;
    height: 42px;
    border-radius: 999px;
  }

  .product-carousel-track {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 78%;
    gap: 14px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    padding-bottom: 4px;
    -webkit-overflow-scrolling: touch;
  }

  .product-carousel-track > * {
    scroll-snap-align: start;
  }

  .product-carousel-track::-webkit-scrollbar {
    display: none;
  }

  /* Merch and account strips */
  .merch-large {
    min-height: 300px;
  }

  .merch-overlay {
    max-width: none;
  }

  .merch-overlay h2 {
    max-width: 15ch;
    margin-bottom: 14px;
  }

  .account-entry-card {
    gap: 14px;
  }

  .account-entry-actions {
    display: grid;
    gap: 10px;
  }

  .account-entry-actions .btn {
    width: 100%;
  }

  /* Repair form polish */
  .repair-zone {
    gap: 16px;
  }

  .service-card,
  .premium-strip-grid article,
  .support-card,
  .merch-card.small {
    border-radius: 18px;
  }

  .booking-form input,
  .booking-form select,
  .booking-form textarea {
    font-size: 16px; /* prevents iOS zoom */
  }

  .booking-form .btn {
    width: 100%;
    min-height: 50px;
  }
}

/* Slightly improve tablet behavior too */
@media (min-width: 761px) and (max-width: 1100px) {
  .header-main {
    grid-template-columns: 1fr;
  }

  .header-search input {
    min-width: 0;
  }

  .premium-hero-grid,
  .hero-support-cards,
  .merchandising-grid,
  .repair-zone {
    gap: 16px;
  }

  .hero-copy-wrap {
    padding: 30px 26px;
  }

  .product-carousel-track {
    grid-auto-columns: 38%;
  }
}