/* =================================================================
   Laptops Repair Dubai — SITE-WIDE STYLESHEET (one file, all pages)
   Blue on white · dark text · cached once for fast page loads
   ================================================================= */
:root{
  --bg:#fff; --soft:#F4F8FF; --ink:#0F1B33; --text:#1E2A44; --muted:#50596F;
  --line:#E5E9F2; --blue:#2563EB; --blue-d:#1D4FD7; --blue-dd:#1A45BE;
  --tint:#EAF1FF; --wa:#15803D; --wa-dd:#0F6330; --amber:#FF9F0A;
  --mono:ui-monospace,SFMono-Regular,"SF Mono",Menlo,Consolas,monospace;
  --f:"Figtree",system-ui,-apple-system,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;overflow-x:clip}
body{font-family:var(--f);background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:clip}
img{max-width:100%;display:block}a{text-decoration:none;color:inherit}
h1,h2,h3,h4{color:var(--ink);line-height:1.14;letter-spacing:-.02em;font-weight:800}
.wrap{max-width:1180px;margin:0 auto;padding:0 22px}
section{padding:66px 0}
svg.ic{width:1em;height:1em;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.eyebrow{font-size:13px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--blue)}
.shead{text-align:center;max-width:720px;margin:0 auto 42px}.shead h2{font-size:clamp(27px,4.2vw,38px);margin:10px 0 8px}.shead p{color:var(--muted);font-size:16.5px}
/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:800;font-size:15px;padding:14px 24px;border-radius:14px;cursor:pointer;border:0;transition:transform .08s,box-shadow .08s;position:relative;top:0;justify-content:center;text-align:center}
.btn .ic{font-size:18px}
.btn-p{background:linear-gradient(180deg,#3470f3,var(--blue));color:#fff;box-shadow:0 5px 0 var(--blue-dd)}.btn-p:hover{top:2px;box-shadow:0 3px 0 var(--blue-dd)}.btn-p:active{top:5px;box-shadow:0 0 0 var(--blue-dd)}
.btn-w{background:var(--wa);color:#fff;box-shadow:0 5px 0 var(--wa-dd)}.btn-w:hover{top:2px;box-shadow:0 3px 0 var(--wa-dd)}.btn-w:active{top:5px;box-shadow:0 0 0 var(--wa-dd)}
.btn-o{background:#fff;color:var(--ink);box-shadow:0 5px 0 var(--line)}.btn-o:hover{top:2px;box-shadow:0 3px 0 var(--line)}
/* top bar */
.topb{background:var(--tint);color:#3a4a68;font-size:13px;border-bottom:1px solid var(--line)}
.topb .wrap{display:flex;justify-content:space-between;align-items:center;height:38px}
.topb a{color:var(--blue-d);font-weight:700}.topb .dot{display:inline-flex;align-items:center;gap:7px;color:var(--blue-d);font-weight:700}
.topb .dot i{width:8px;height:8px;border-radius:50%;background:var(--blue);box-shadow:0 0 0 0 rgba(37,99,235,.5);animation:pl 2s infinite}
@keyframes pl{70%{box-shadow:0 0 0 8px rgba(37,99,235,0)}}
@media(max-width:680px){.topb .l{display:none}.topb .wrap{justify-content:center;gap:18px}}
/* header */
.hdr{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.94);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:70px;gap:14px}
.brand{display:flex;align-items:center;gap:10px;flex-shrink:0;white-space:nowrap}
.brand-logo{height:46px;width:auto}
.brand-fb{display:none;align-items:center;gap:9px;font-weight:900;font-size:17px;color:var(--ink);white-space:nowrap}
.brand-fb i{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#3470f3,var(--blue));display:grid;place-items:center;color:#fff;flex-shrink:0}
.menu{display:flex;gap:0;list-style:none}.menu>li{position:relative}
.menu>li>a{display:flex;align-items:center;gap:4px;padding:9px 11px;font-weight:600;font-size:14px;color:var(--text);border-radius:9px;transition:.15s;white-space:nowrap}
.menu>li>a:hover{background:var(--tint);color:var(--blue-d)}.menu .caret{width:12px;height:12px;opacity:.6}
.dd{position:absolute;top:calc(100% + 8px);left:0;min-width:248px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 18px 40px -16px rgba(15,27,51,.25);padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.18s;list-style:none;z-index:60}
.dd.wide{min-width:516px;display:grid;grid-template-columns:1fr 1fr;gap:2px}
.menu>li:hover .dd,.menu>li:focus-within .dd{opacity:1;visibility:visible;transform:none}
.dd a{display:flex;align-items:center;gap:9px;padding:10px 12px;border-radius:9px;font-size:14px;color:var(--text)}
.dd a:hover{background:var(--tint);color:var(--blue-d)}.dd a svg{width:17px;height:17px;color:var(--blue);flex-shrink:0}
.nav-cta{display:flex;gap:9px;align-items:center;flex-shrink:0}.nav-cta .btn{padding:12px 16px;font-size:14px}
.burger{display:none;width:46px;height:46px;border:1.5px solid var(--line);border-radius:11px;background:#fff;cursor:pointer;font-size:22px;color:var(--ink)}
@media(max-width:1140px){.menu{display:none}.burger{display:block}.nav-cta .btn span{display:none}.nav-cta .btn{padding:12px 14px}}
@media(max-width:600px){.nav-cta .btn{display:none}}
.mnav{display:none;background:#fff;border-bottom:1px solid var(--line);padding:8px 22px 16px}.mnav.on{display:block}
.mnav>a{display:block;padding:13px 4px;font-weight:700;border-bottom:1px solid var(--line)}
.mnav details{border-bottom:1px solid var(--line)}.mnav summary{padding:13px 4px;font-weight:700;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center}
.mnav summary::-webkit-details-marker{display:none}.mnav summary::after{content:"+";color:var(--blue-d);font-size:19px}.mnav details[open] summary::after{content:"–"}
.mnav .sub a{display:block;padding:10px 4px 10px 16px;font-size:14px;color:var(--muted)}
.mnav .mbtns{display:grid;gap:10px;margin-top:14px}.mnav .btn{width:100%}
/* breadcrumb bar */
.crumb{background:var(--soft);border-bottom:1px solid var(--line);font-size:13px}
.crumb .wrap{display:flex;align-items:center;gap:8px;height:46px;flex-wrap:wrap;color:var(--muted)}
.crumb a{color:var(--blue-d);font-weight:600}.crumb a:hover{text-decoration:underline}
.crumb span.sep{color:#b9c3d6}.crumb span.cur{color:var(--text);font-weight:600}
/* page hero */
.phero{padding:46px 0 40px;background:radial-gradient(120% 90% at 85% 0%,var(--tint),#fff 70%)}
.phero .badge{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1.5px solid var(--tint);color:var(--blue-d);font-weight:800;font-size:12.5px;padding:7px 14px;border-radius:999px;margin-bottom:16px;box-shadow:0 3px 0 var(--tint)}
.phero h1{font-size:clamp(30px,4.6vw,46px);line-height:1.07;letter-spacing:-.025em;max-width:880px}
.phero h1 .u{color:var(--blue);text-decoration:underline;text-decoration-color:var(--amber);text-decoration-thickness:5px;text-underline-offset:5px}
.phero .lead{font-size:17.5px;color:var(--muted);margin:16px 0 22px;max-width:660px}
.phero .hcta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.phero .badges{display:flex;flex-wrap:wrap;gap:10px}
.b3d{display:flex;align-items:center;gap:8px;background:#fff;border-radius:12px;padding:10px 15px;box-shadow:0 4px 0 var(--line);font-weight:700;font-size:13px;color:var(--ink)}.b3d .ic{font-size:17px;color:var(--blue)}
.rate-inline{display:inline-flex;align-items:center;gap:7px;font-size:14px;color:var(--muted);margin-top:4px}.rate-inline b{color:var(--ink)}.rate-inline .stars{color:var(--amber);letter-spacing:1px}
/* 2-col layout: content + sidebar */
.layout{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:40px;align-items:start}
@media(max-width:960px){.layout{grid-template-columns:minmax(0,1fr);gap:30px}}
/* prose / article body */
.prose>*+*{margin-top:18px}
.prose h2{font-size:clamp(23px,3vw,30px);margin-top:42px;scroll-margin-top:90px}
.prose h3{font-size:19px;margin-top:30px;color:var(--ink)}
.prose p,.prose li{font-size:16px;color:var(--text);line-height:1.7}
.prose ul,.prose ol{padding-left:4px;list-style:none;display:grid;gap:11px}
.prose ul li{position:relative;padding-left:30px}
.prose ul li::before{content:"";position:absolute;left:0;top:3px;width:19px;height:19px;border-radius:6px;background:var(--tint);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='13' height='13' viewBox='0 0 24 24' fill='none' stroke='%232563EB' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}
.prose ol{counter-reset:n}.prose ol li{position:relative;padding-left:38px;counter-increment:n}
.prose ol li::before{content:counter(n);position:absolute;left:0;top:0;width:26px;height:26px;border-radius:8px;background:var(--blue);color:#fff;font-weight:800;font-size:13px;display:grid;place-items:center;font-family:var(--mono)}
.prose strong{color:var(--ink)}.prose a{color:var(--blue-d);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.prose blockquote{border-left:4px solid var(--blue);background:var(--soft);padding:16px 20px;border-radius:0 12px 12px 0;color:var(--text);font-style:italic}
.prose table{width:100%;border-collapse:collapse;font-size:14.5px;margin-top:8px;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.prose th,.prose td{padding:13px 16px;text-align:left;border-bottom:1px solid var(--line)}
.prose thead th{background:var(--soft);font-family:var(--mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}
.prose tbody tr:last-child td{border-bottom:0}.prose tbody tr:hover{background:var(--tint)}
/* callout */
.callout{display:flex;gap:13px;background:var(--soft);border:1px solid var(--line);border-left:4px solid var(--blue);border-radius:12px;padding:18px 20px}
.callout .ic{color:var(--blue);font-size:22px;flex-shrink:0}.callout b{color:var(--ink)}.callout p{font-size:14.5px;color:var(--muted);margin-top:2px}
/* sidebar cards */
.aside{display:grid;gap:18px;position:sticky;top:90px}
@media(max-width:960px){.aside{position:static}}
.side-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:22px;box-shadow:0 5px 0 var(--line)}
.side-card.accent{background:linear-gradient(165deg,#fff,var(--tint));border-color:#d8e4ff}
.side-card h3{font-size:18px;margin-bottom:6px}.side-card p{font-size:13.5px;color:var(--muted);margin-bottom:14px}
.side-card .btn{width:100%;margin-bottom:9px}.side-card .btn:last-child{margin-bottom:0}
.side-mini{display:flex;align-items:center;gap:10px;padding:10px 0;border-top:1px solid var(--line);font-size:13.5px;color:var(--text)}.side-mini .ic{color:var(--blue);font-size:18px;flex-shrink:0}.side-mini b{color:var(--ink)}
.side-links h4{font-size:12px;text-transform:uppercase;letter-spacing:.07em;color:var(--ink);margin-bottom:12px}
.side-links a{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:11px 0;border-bottom:1px solid var(--line);font-size:14px;font-weight:600;color:var(--text)}
.side-links a:last-child{border-bottom:0}.side-links a:hover{color:var(--blue-d)}.side-links a svg{width:15px;height:15px;color:var(--muted)}.side-links a:hover svg{color:var(--blue-d)}
/* trust row / stats inline */
.trustrow{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:center;background:var(--soft);border:1px solid var(--line);border-radius:16px;padding:26px 18px}
.trustrow .n{font-size:clamp(24px,4vw,34px);font-weight:900;color:var(--blue);line-height:1}.trustrow .n .ic{color:var(--amber);font-size:.7em}.trustrow small{color:var(--muted);font-size:13px;display:block;margin-top:5px}
@media(max-width:620px){.trustrow{grid-template-columns:1fr 1fr;gap:24px 18px}}
/* cards / grids (shared) */
.grid{display:grid;gap:16px}.g4{grid-template-columns:repeat(4,1fr)}.g3{grid-template-columns:repeat(3,1fr)}.g2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:0 4px 0 var(--line);transition:transform .15s,box-shadow .15s}
.card:hover{transform:translateY(-4px);box-shadow:0 8px 0 var(--tint),0 18px 34px -18px rgba(37,99,235,.4)}
.scard{display:flex;gap:14px;align-items:flex-start}
.scard .sicn{width:48px;height:48px;border-radius:13px;background:var(--tint);display:grid;place-items:center;color:var(--blue);font-size:23px;flex-shrink:0;box-shadow:0 3px 0 #d8e4ff}
.scard h3{font-size:15.5px;margin-bottom:4px}.scard p{font-size:13px;color:var(--muted);line-height:1.45}
@media(max-width:900px){.g4,.g3{grid-template-columns:repeat(2,1fr)}}@media(max-width:560px){.g4,.g3,.g2{grid-template-columns:1fr}}
/* steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;counter-reset:s}
.steps .step{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px 20px;box-shadow:0 4px 0 var(--line);position:relative;counter-increment:s}
.steps .step::before{content:counter(s);width:38px;height:38px;border-radius:11px;background:linear-gradient(180deg,#3470f3,var(--blue));color:#fff;font-weight:900;display:grid;place-items:center;margin-bottom:14px;box-shadow:0 4px 0 var(--blue-dd)}
.steps .step h3{font-size:16px;margin-bottom:5px}.steps .step p{font-size:13.5px;color:var(--muted)}
@media(max-width:820px){.steps{grid-template-columns:1fr 1fr}}@media(max-width:480px){.steps{grid-template-columns:1fr}}
/* internal-link chips + clouds */
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chips a{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:9px 16px;font-size:13.5px;font-weight:600;color:var(--text);box-shadow:0 3px 0 var(--line);transition:.15s}
.chips a:hover{color:var(--blue-d);border-color:var(--tint);box-shadow:0 3px 0 var(--tint)}.chips a svg{width:14px;height:14px;color:var(--blue)}
.cloud{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.cloud a{display:flex;align-items:center;justify-content:space-between;gap:10px;background:#fff;border:1px solid var(--line);border-radius:11px;padding:14px 17px;font-weight:600;font-size:14px;color:var(--text);box-shadow:0 3px 0 var(--line);transition:.15s}
.cloud a:hover{color:var(--blue-d);transform:translateX(3px);box-shadow:0 3px 0 var(--tint);border-color:var(--tint)}.cloud a svg{width:16px;height:16px;color:var(--muted);flex-shrink:0}.cloud a:hover svg{color:var(--blue-d)}
@media(max-width:820px){.cloud{grid-template-columns:repeat(2,1fr)}}@media(max-width:520px){.cloud{grid-template-columns:1fr}}
.area-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.area-grid a{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-radius:11px;padding:13px 16px;font-size:14px;font-weight:600;color:var(--text);box-shadow:0 3px 0 var(--line);transition:.15s}
.area-grid a:hover{color:var(--blue-d);box-shadow:0 3px 0 var(--tint);border-color:var(--tint)}.area-grid a svg{width:16px;height:16px;color:var(--blue);flex-shrink:0}
@media(max-width:820px){.area-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.area-grid{grid-template-columns:1fr}}
/* reviews */
.rev-rail{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;padding:6px 2px 18px}
.rev-rail::-webkit-scrollbar{height:6px}.rev-rail::-webkit-scrollbar-thumb{background:var(--line);border-radius:6px}
.rev-card{scroll-snap-align:start;flex:0 0 340px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px;box-shadow:0 4px 0 var(--line)}
.rev-card .stars{color:var(--amber);font-size:15px;letter-spacing:1px}
.rev-card p{font-size:14.5px;color:var(--text);margin:13px 0 18px;line-height:1.6}
.rev-user{display:flex;align-items:center;gap:12px}.rev-av{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#3470f3,var(--blue));color:#fff;display:grid;place-items:center;font-weight:800;font-size:16px}
.rev-user b{font-size:14.5px;color:var(--ink);display:block}.rev-user small{font-size:12px;color:var(--muted)}
@media(max-width:520px){.rev-card{flex-basis:280px}}
/* FAQ */
.faq-list{max-width:860px;margin:0 auto}
.faq-list details{border:1px solid var(--line);border-radius:14px;margin-bottom:12px;background:#fff;box-shadow:0 4px 0 var(--line);overflow:hidden;transition:.2s}
.faq-list details[open]{box-shadow:0 4px 0 var(--tint);border-color:var(--tint)}
.faq-list summary{padding:19px 22px;font-weight:800;font-size:16px;color:var(--ink);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{content:"";width:11px;height:11px;border-right:2.4px solid var(--blue);border-bottom:2.4px solid var(--blue);transform:rotate(45deg);transition:.2s;flex-shrink:0;margin-top:-4px}
.faq-list details[open] summary::after{transform:rotate(225deg);margin-top:4px}
.faq-list .ans{padding:0 22px 20px;color:var(--muted);font-size:15px;line-height:1.65}.faq-list .ans strong{color:var(--ink)}
/* CTA */
.cta{background:var(--tint);border:1px solid #d8e4ff;border-radius:26px;padding:50px 30px;text-align:center;box-shadow:0 5px 0 #d8e4ff}
.cta h2{color:var(--ink);font-size:clamp(25px,3.6vw,38px)}.cta p{color:var(--muted);font-size:17px;max-width:540px;margin:12px auto 26px}.cta .hcta{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}
/* footer */
.ft{background:#fff;border-top:1px solid var(--line);padding:52px 0 0;color:var(--muted);font-size:14px}
.ft a{color:var(--text)}.ft a:hover{color:var(--blue-d)}
.ftt{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.4fr;gap:36px;padding-bottom:36px;border-bottom:1px solid var(--line)}
.ft h4{font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink);margin-bottom:16px}.ft ul{list-style:none;display:grid;gap:10px}
.ft-social{display:flex;gap:10px;margin-top:16px}.ft-social a{width:38px;height:38px;border-radius:10px;background:var(--soft);display:grid;place-items:center;color:var(--blue-d)}.ft-social a:hover{background:var(--blue);color:#fff}.ft-social svg{width:18px;height:18px}
.napr{display:flex;gap:11px;align-items:flex-start;margin-bottom:11px;font-size:13.5px}.napr .ic{color:var(--blue-d);font-size:17px;flex-shrink:0;margin-top:2px}
.ft-map{display:block;width:100%;border:0;border-radius:12px;margin-top:14px}
.ft-disc{font-size:11.5px;color:var(--muted);line-height:1.6;padding:18px 0;border-top:1px solid var(--line)}
.ftb{padding:18px 0;font-size:12.5px;text-align:center;border-top:1px solid var(--line)}
.ftb a{text-decoration:underline;text-underline-offset:2px;font-weight:600}
.sronly{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
@media(max-width:840px){.ftt{grid-template-columns:1fr 1fr}}@media(max-width:520px){.ftt{grid-template-columns:1fr}}
/* floating contact cluster + talk popup */
.fabw{position:fixed;right:16px;bottom:16px;z-index:300;display:flex;flex-direction:column;gap:11px;align-items:flex-end}
.fab{position:relative;width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 8px 22px rgba(15,27,51,.28);transition:transform .15s,box-shadow .15s}
.fab:hover{transform:translateY(-3px);box-shadow:0 13px 28px rgba(15,27,51,.34)}
.fab svg{width:26px;height:26px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.fab-call{background:linear-gradient(180deg,#3470f3,var(--blue))}.fab-wa{background:var(--wa)}
.fab-talk{display:flex;align-items:center;gap:11px;background:linear-gradient(180deg,#3470f3,var(--blue));color:#fff;border:0;cursor:pointer;border-radius:999px;padding:9px 18px 9px 10px;box-shadow:0 9px 24px rgba(37,99,235,.42);transition:transform .15s,box-shadow .15s;font-family:var(--f)}
.fab-talk:hover{transform:translateY(-3px);box-shadow:0 13px 30px rgba(37,99,235,.5)}
.fab-talk-ic{position:relative;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.2);display:grid;place-items:center;flex-shrink:0}
.fab-talk-ic svg{width:21px;height:21px;fill:none;stroke:#fff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.fab-online{position:absolute;right:-1px;top:-1px;width:11px;height:11px;border-radius:50%;background:#34e27a;border:2px solid #2b62e6;box-shadow:0 0 0 0 rgba(52,226,122,.7);animation:fabpulse 2s infinite}
@keyframes fabpulse{70%{box-shadow:0 0 0 7px rgba(52,226,122,0)}100%{box-shadow:0 0 0 0 rgba(52,226,122,0)}}
.fab-talk-tx{text-align:left;line-height:1.15;white-space:nowrap}.fab-talk-tx b{font-size:13.5px;font-weight:800;display:block}.fab-talk-tx small{font-size:11px;opacity:.88}
@media(max-width:560px){.fab{width:50px;height:50px}.fab svg{width:24px;height:24px}.fab-talk-tx b{font-size:12.5px}.fab-talk-tx small{font-size:10.5px}}
.tt-overlay{position:fixed;inset:0;z-index:400;background:rgba(15,27,51,.55);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:18px;opacity:0;transition:opacity .2s}
.tt-overlay.on{opacity:1}.tt-overlay[hidden]{display:none}
.tt-card{background:#fff;border-radius:22px;width:100%;max-width:400px;padding:24px;box-shadow:0 30px 70px -20px rgba(15,27,51,.5);position:relative;transform:translateY(16px) scale(.98);transition:transform .22s;max-height:92vh;overflow-y:auto}
.tt-overlay.on .tt-card{transform:none}
.tt-x{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;border:0;background:var(--soft);color:var(--ink);font-size:22px;line-height:1;cursor:pointer;display:grid;place-items:center}.tt-x:hover{background:var(--tint)}
.tt-head{display:flex;align-items:center;gap:13px;padding-right:30px;margin-bottom:18px}
.tt-av{position:relative;width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,#3470f3,var(--blue));display:grid;place-items:center;flex-shrink:0}
.tt-av svg{width:25px;height:25px;fill:none;stroke:#fff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.tt-on{position:absolute;right:0;bottom:1px;width:13px;height:13px;border-radius:50%;background:#34c759;border:2.5px solid #fff}
.tt-head b{font-size:16.5px;color:var(--ink);display:block}.tt-head small{font-size:12.5px;color:var(--muted)}
.tt-quick{display:grid;grid-template-columns:1fr 1fr;gap:10px}.tt-quick .btn{width:100%;padding:13px}
.tt-or{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:12px;margin:16px 0;text-transform:uppercase;letter-spacing:.05em;font-weight:700}
.tt-or::before,.tt-or::after{content:"";flex:1;height:1px;background:var(--line)}
.tt-form{display:grid;gap:11px}
.qf-input{width:100%;border:1.5px solid var(--line);border-radius:12px;padding:13px 15px;font-family:var(--f);font-size:15px;color:var(--ink);background:#fff;transition:.12s}
.qf-input:focus{outline:0;border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.12)}
.opts{display:flex;flex-wrap:wrap;gap:8px}
.opt{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1.5px solid var(--line);border-radius:999px;padding:8px 14px;font-size:13px;font-weight:600;color:var(--text);cursor:pointer;transition:.12s;user-select:none}
.opt:hover{border-color:#c7d6f5}.opt.sel{background:var(--tint);border-color:var(--blue);color:var(--blue-d);box-shadow:0 3px 0 #d8e4ff}
.tt-send{width:100%;margin-top:3px}.tt-note{text-align:center;font-size:12px;color:var(--muted);margin-top:2px}
/* price table */
.ptable-wrap{border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:0 5px 0 var(--line);background:#fff}
.ptable-bar{display:flex;align-items:center;gap:10px;padding:14px 20px;background:var(--soft);border-bottom:1px solid var(--line);font-weight:800;color:var(--ink);font-size:14.5px}
.ptable-bar svg{width:18px;height:18px;color:var(--blue)}
.ptable-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
.ptable{width:100%;min-width:520px;border-collapse:collapse;font-size:14.5px}
.ptable th,.ptable td{padding:13px 20px;text-align:left;border-bottom:1px solid var(--line)}
.ptable thead th{font-family:var(--mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);font-weight:700;background:#fbfcff}
.ptable td:first-child{font-weight:600;color:var(--ink)}
.ptable .pr{font-family:var(--mono);color:var(--blue);font-weight:800;white-space:nowrap}
.ptable .tt{font-family:var(--mono);color:var(--muted);font-size:12.5px;white-space:nowrap}
.ptable tbody tr:last-child td{border-bottom:0}.ptable tbody tr:hover{background:var(--tint)}
.ptable-note{font-size:12.5px;color:var(--muted);padding:13px 20px;background:#fbfcff;border-top:1px solid var(--line)}
/* picture gallery — figure + caption, zero CLS via aspect-ratio */
.pgal{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:24px 0}
.pgal figure{margin:0;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#fff;box-shadow:0 4px 0 var(--line)}
.pgal img{width:100%;height:auto;display:block;aspect-ratio:600/450;background:var(--soft)}
.pgal figcaption{padding:12px 16px;font-size:13.5px;font-weight:600;color:var(--text);background:#fbfcff;border-top:1px solid var(--line)}
@media(max-width:560px){.pgal{grid-template-columns:1fr;gap:14px}}
/* horizontal 4-up gallery — square ~250px cells, placeholder-aware */
.pgal4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:24px 0}
.pgal4 figure{margin:0;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff;box-shadow:0 4px 0 var(--line)}
.pgal4 .ph{position:relative;aspect-ratio:1/1;background:var(--soft);display:grid;place-items:center;text-align:center}
.pgal4 .ph .lbl{font-family:var(--mono);font-size:10px;color:var(--muted);line-height:1.55;padding:8px;word-break:break-word}
.pgal4 .ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.pgal4 figcaption{padding:10px 12px;font-size:12.5px;font-weight:600;color:var(--text);background:#fbfcff;border-top:1px solid var(--line)}
@media(max-width:720px){.pgal4{grid-template-columns:1fr 1fr}}
/* hero banner image — full content width, .webp, zero-CLS */
.pbanner{margin:8px 0 2px}
.pbanner .ph{position:relative;aspect-ratio:700/300;border-radius:18px;overflow:hidden;border:1px solid var(--line);background:var(--soft);display:grid;place-items:center;text-align:center;box-shadow:0 6px 0 var(--line)}
.pbanner .ph .lbl{font-family:var(--mono);font-size:12.5px;color:var(--muted);line-height:1.7;padding:12px;word-break:break-word}
.pbanner .ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
@media(max-width:600px){.pbanner .ph .lbl{font-size:10px}}
/* light content-protection */
img{-webkit-user-drag:none;-khtml-user-drag:none;user-drag:none;-webkit-touch-callout:none}
.sec-soft{background:var(--soft)}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
