@import url('https://fonts.googleapis.com/css2?family=Kanit:wght@400;500;600;700;800;900&family=Prompt:wght@400;500;600;700;800&display=swap');

:root{
  --font-main:"Prompt","Noto Sans Thai",Tahoma,Arial,sans-serif;
  --font-display:"Kanit","Prompt","Noto Sans Thai",Tahoma,Arial,sans-serif;
  --bg:#f6f9fc;
  --bg2:#eef5fb;
  --panel:#ffffff;
  --panel2:#f2f7fc;
  --text:#122033;
  --muted:#5f6f82;
  --line:rgba(18,32,51,.13);
  --blue:#27c7ff;
  --blue2:#2267ff;
  --gold:#f6c453;
  --green:#2fd78b;
  --red:#ff5c6c;
  --shadow:0 24px 70px rgba(32,76,125,.16);
  --radius:28px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font-main);font-weight:400;line-height:1.78;overflow-x:hidden;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
h1,h2,h3,.brand-text,.main-nav a,.btn,.kicker,.eyebrow,.point strong,.mini-badge,.price-note,.step:before,.footer-brand{font-family:var(--font-display);font-weight:700}
.container{width:min(1180px,calc(100% - 36px));margin:0 auto}
.topline{background:rgba(255,255,255,.92);border-bottom:1px solid var(--line);font-size:14px;color:#22374f}
.topbar{min-height:38px;display:flex;gap:20px;align-items:center;justify-content:flex-end;flex-wrap:wrap}
.topbar span{margin-right:auto;color:var(--muted)}
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.88);backdrop-filter:blur(18px);border-bottom:1px solid var(--line);box-shadow:0 10px 30px rgba(20,60,100,.07)}
.nav-wrap{min-height:78px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:13px;min-width:max-content}
.brand-mark{width:48px;height:48px;border-radius:16px;display:grid;place-items:center;font-weight:900;font-size:28px;color:#fff;background:linear-gradient(135deg,var(--blue),var(--blue2) 52%,var(--gold));box-shadow:0 12px 30px rgba(39,126,255,.28)}
.brand-text{display:flex;flex-direction:column;line-height:1.15;letter-spacing:.04em}
.brand-text strong{font-size:22px;background:linear-gradient(90deg,#152236,var(--blue2),#b88616);-webkit-background-clip:text;background-clip:text;color:transparent}
.brand-text em{font-style:normal;font-size:12px;color:var(--muted);letter-spacing:.14em;text-transform:uppercase}
.main-nav{display:flex;align-items:center;gap:8px}
.main-nav a{padding:10px 14px;border-radius:999px;color:#263a52;font-weight:700;font-size:15px;transition:.25s ease}
.main-nav a:hover,.main-nav a.is-active{background:rgba(39,199,255,.12);color:#0d5fc2;box-shadow:inset 0 0 0 1px rgba(39,199,255,.28)}
.nav-toggle{display:none;width:46px;height:42px;border:1px solid var(--line);background:#fff;border-radius:14px;padding:10px;cursor:pointer}
.nav-toggle span{display:block;height:2px;background:#19324d;margin:5px 0;border-radius:99px}
.hero{position:relative;min-height:720px;display:flex;align-items:center;overflow:hidden;background:radial-gradient(circle at 15% 20%,rgba(39,199,255,.18),transparent 32%),radial-gradient(circle at 80% 16%,rgba(246,196,83,.22),transparent 30%),linear-gradient(135deg,#ffffff,#edf7ff 55%,#f8fbff)}
.hero:before{content:"";position:absolute;inset:0;background:url('../img/araiyon-hybrid-car-service-hero.webp') center/cover no-repeat;opacity:.14;filter:saturate(1.05)}
.hero:after{content:"";position:absolute;inset:-30%;background:repeating-linear-gradient(115deg,rgba(20,96,160,.06) 0 1px,transparent 1px 22px);animation:scanMove 18s linear infinite;opacity:.75;pointer-events:none}
@keyframes scanMove{from{transform:translate3d(-3%,0,0)}to{transform:translate3d(3%,0,0)}}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding:80px 0}
.kicker{display:inline-flex;align-items:center;gap:9px;padding:8px 14px;border:1px solid rgba(39,126,255,.24);border-radius:999px;background:rgba(39,199,255,.10);color:#0d5b95;font-weight:800;font-size:14px;box-shadow:0 14px 34px rgba(39,126,255,.10)}
.kicker:before{content:"";width:9px;height:9px;border-radius:99px;background:var(--green);box-shadow:0 0 18px var(--green)}
h1{font-size:clamp(38px,5.7vw,76px);line-height:1.08;margin:18px 0 18px;letter-spacing:-.02em;font-weight:800}
.hero h1{font-size:clamp(19px,2.85vw,38px);line-height:1.18;max-width:820px}
.grad{background:linear-gradient(90deg,#17253a 10%,#0d78d8 44%,#c28b18 86%);-webkit-background-clip:text;background-clip:text;color:transparent}
.lead{font-size:clamp(17px,2vw,22px);color:#40556e;max-width:790px;margin:0 0 30px;font-weight:500}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:34px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:14px 20px;border-radius:999px;font-weight:900;border:1px solid transparent;transition:.25s ease;cursor:pointer}
.btn-primary{background:linear-gradient(135deg,var(--blue),var(--blue2));color:white;box-shadow:0 14px 34px rgba(34,103,255,.34)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 40px rgba(34,103,255,.45)}
.btn-ghost{border-color:rgba(20,60,100,.16);background:#fff;color:#17324d;box-shadow:0 12px 28px rgba(30,80,130,.08)}
.btn-ghost:hover{border-color:rgba(246,196,83,.5);background:rgba(246,196,83,.1);transform:translateY(-2px)}
.hero-points{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;max-width:790px}
.point{padding:16px;border-radius:20px;background:rgba(255,255,255,.86);border:1px solid rgba(18,32,51,.10);box-shadow:0 14px 30px rgba(28,79,130,.08)}
.point strong{display:block;font-size:20px;color:#16283d}.point span{font-size:14px;color:var(--muted)}
.hero-card{position:relative;border:1px solid rgba(18,32,51,.12);border-radius:var(--radius);background:linear-gradient(180deg,rgba(255,255,255,.95),rgba(245,250,255,.86));box-shadow:var(--shadow);overflow:hidden;transform:perspective(900px) rotateY(-4deg);animation:floatCard 5.5s ease-in-out infinite}
@keyframes floatCard{0%,100%{transform:perspective(900px) rotateY(-4deg) translateY(0)}50%{transform:perspective(900px) rotateY(-4deg) translateY(-12px)}}
.hero-card img{width:100%;height:420px;object-fit:cover;opacity:.92}
.hero-card-content{padding:24px;background:linear-gradient(0deg,rgba(255,255,255,.98),rgba(247,251,255,.94))}
.hero-card-content h2{margin:0 0 12px;font-size:28px;color:#16283d}.hero-card-content p{margin:0;color:var(--muted)}
.badge-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:18px}
.mini-badge{padding:12px;border-radius:16px;background:rgba(39,199,255,.10);border:1px solid rgba(39,126,255,.18);font-weight:900;color:#123b62;text-align:center}
.section{position:relative;padding:96px 0;background:linear-gradient(180deg,#f8fbff,#eef6fd)}
.section.alt{background:linear-gradient(180deg,#eef6fd,#ffffff)}
.section:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 10% 15%,rgba(39,199,255,.10),transparent 30%),radial-gradient(circle at 92% 32%,rgba(246,196,83,.12),transparent 26%);pointer-events:none}
.section > .container{position:relative;z-index:2}
.section-head{max-width:840px;margin:0 auto 42px;text-align:center}
.eyebrow{color:var(--gold);font-weight:900;letter-spacing:.12em;text-transform:uppercase;font-size:13px}.section h2{font-size:clamp(30px,4vw,48px);line-height:1.2;margin:8px 0 12px;font-weight:800;color:#16283d}.section-head p{color:var(--muted);font-size:18px;margin:0}
.grid{display:grid;gap:22px}.grid-4{grid-template-columns:repeat(4,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-2{grid-template-columns:repeat(2,1fr)}
.card{position:relative;overflow:hidden;border:1px solid rgba(18,32,51,.11);border-radius:var(--radius);background:linear-gradient(180deg,#ffffff,#f8fbff);box-shadow:0 16px 44px rgba(28,70,115,.12);transition:.3s ease}
.card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(39,199,255,.16),transparent 35%,rgba(246,196,83,.11));opacity:0;transition:.3s ease;pointer-events:none}.card:hover{transform:translateY(-8px);border-color:rgba(39,199,255,.33)}.card:hover:before{opacity:1}
.card-body{position:relative;z-index:2;padding:24px}.icon{width:54px;height:54px;border-radius:18px;display:grid;place-items:center;margin-bottom:16px;background:linear-gradient(135deg,rgba(39,199,255,.16),rgba(246,196,83,.18));border:1px solid rgba(18,32,51,.10);font-size:26px}.card h3{margin:0 0 10px;font-size:22px;font-weight:700;color:#16283d}.card p{color:var(--muted);margin:0}.card ul{margin:12px 0 0;padding-left:20px;color:#43566c}
.image-card img{height:230px;width:100%;object-fit:cover}.image-card .card-body{padding:22px}.price-note{display:inline-flex;margin-top:14px;padding:7px 12px;border-radius:999px;background:rgba(246,196,83,.18);color:#8a650f;font-weight:800;font-size:13px;border:1px solid rgba(246,196,83,.28)}
.process{counter-reset:step}.step{display:grid;grid-template-columns:58px 1fr;gap:16px;align-items:start;padding:22px;border-radius:24px;border:1px solid var(--line);background:#fff;box-shadow:0 12px 32px rgba(28,70,115,.08)}.step:before{counter-increment:step;content:counter(step);width:58px;height:58px;border-radius:20px;display:grid;place-items:center;background:linear-gradient(135deg,var(--blue2),var(--blue));font-weight:900;font-size:24px;box-shadow:0 14px 34px rgba(39,199,255,.2)}.step h3{margin:0 0 6px;color:#16283d}.step p{margin:0;color:var(--muted)}
.cta-band{position:relative;overflow:hidden;border-radius:34px;padding:40px;background:linear-gradient(135deg,rgba(34,103,255,.10),rgba(39,199,255,.10),rgba(246,196,83,.16));border:1px solid rgba(18,32,51,.12);box-shadow:var(--shadow);display:grid;grid-template-columns:1.1fr auto;gap:24px;align-items:center}.cta-band:before{content:"";position:absolute;inset:-60%;background:conic-gradient(from 180deg,transparent,rgba(255,255,255,.18),transparent 20%);animation:spin 8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.cta-band > *{position:relative}.cta-band h2{margin:0 0 10px;color:#16283d}.cta-band p{margin:0;color:#4c5f73}.cta-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:flex-end}
.page-hero{padding:74px 0 52px;background:radial-gradient(circle at 20% 0%,rgba(39,199,255,.18),transparent 32%),linear-gradient(135deg,#ffffff,#eef7ff);border-bottom:1px solid var(--line)}.page-hero h1{font-size:clamp(34px,4.6vw,58px);margin:10px 0;color:#16283d}.breadcrumb{color:var(--muted);font-size:14px}.breadcrumb a{color:#0d5fc2}.page-hero p{max-width:840px;color:#40556e;font-size:18px;margin:0}
.split{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}.split .media{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);background:linear-gradient(135deg,#ffffff,#edf7ff)}.split .media img{width:100%;height:420px;object-fit:cover}.split .media-fit{padding:14px}.split .media-fit img{height:420px;object-fit:contain;border-radius:22px}.check-list{display:grid;gap:12px;margin-top:22px}.check{display:flex;gap:12px;align-items:flex-start;padding:14px 16px;border-radius:18px;background:#fff;border:1px solid var(--line);box-shadow:0 10px 28px rgba(28,70,115,.08)}.check:before{content:"✓";width:26px;height:26px;min-width:26px;border-radius:99px;background:rgba(47,215,139,.16);color:#6dffb4;display:grid;place-items:center;font-weight:900}.check strong{display:block;color:#16283d}.check span{display:block;color:var(--muted);font-size:14px}
.service-visual{position:relative;min-height:420px;padding:28px;background:radial-gradient(circle at 0% 0%,rgba(39,199,255,.22),transparent 34%),radial-gradient(circle at 94% 8%,rgba(246,196,83,.26),transparent 30%),linear-gradient(135deg,#ffffff,#edf8ff);display:flex;flex-direction:column;justify-content:space-between;isolation:isolate}.service-visual:before{content:"";position:absolute;inset:18px;border:1px solid rgba(34,103,255,.11);border-radius:26px;pointer-events:none}.service-visual:after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(115deg,rgba(34,103,255,.055) 0 1px,transparent 1px 24px);opacity:.75;z-index:-1}.visual-brand{display:flex;align-items:center;gap:16px}.visual-mark{width:62px;height:62px;border-radius:20px;display:grid;place-items:center;background:linear-gradient(135deg,var(--blue2),var(--blue));color:#fff;font-family:var(--font-display);font-weight:900;font-size:34px;box-shadow:0 16px 34px rgba(39,199,255,.24);position:relative}.visual-mark:after{content:"";position:absolute;right:-8px;bottom:-8px;width:28px;height:28px;border-radius:50%;background:var(--gold);box-shadow:0 10px 24px rgba(246,196,83,.28)}.visual-brand strong{display:block;font-family:var(--font-display);font-size:34px;letter-spacing:.05em;line-height:1;color:#17335a}.visual-brand em{display:block;font-style:normal;font-size:13px;letter-spacing:.22em;color:#647488;font-weight:800;margin-top:5px}.visual-content{display:grid;grid-template-columns:1.05fr .95fr;gap:22px;align-items:center}.visual-kicker{display:inline-flex;margin-bottom:8px;padding:6px 12px;border-radius:999px;background:rgba(39,199,255,.12);color:#0d5fc2;font-size:13px;font-weight:800}.visual-copy h3{margin:0 0 8px;color:#14283f;font-size:clamp(24px,2.8vw,38px);line-height:1.22}.visual-copy p{margin:0;color:#455b72;font-size:17px;font-weight:700}.visual-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}.visual-tags span{padding:8px 12px;border-radius:999px;background:#fff;border:1px solid rgba(18,32,51,.11);box-shadow:0 8px 20px rgba(35,75,120,.08);font-weight:800;color:#1e436b;font-size:13px}.visual-car{position:relative;height:210px;border-radius:28px;background:linear-gradient(135deg,#122845,#183d66);box-shadow:0 22px 52px rgba(23,51,90,.25);overflow:hidden}.visual-car:before{content:"";position:absolute;inset:-70px -40px auto auto;width:190px;height:190px;border-radius:50%;background:rgba(39,199,255,.18)}.battery-icon{position:absolute;left:50%;top:34px;transform:translateX(-50%);width:104px;height:42px;border:5px solid #2fd78b;border-radius:10px}.battery-icon:after{content:"";position:absolute;right:-17px;top:11px;width:13px;height:18px;background:#2fd78b;border-radius:0 5px 5px 0}.battery-icon i{position:absolute;top:8px;width:4px;height:20px;background:#74f2b8;border-radius:2px}.battery-icon i:nth-child(1){left:21px}.battery-icon i:nth-child(2){left:49px}.battery-icon i:nth-child(3){left:77px}.car-arc{position:absolute;left:43px;right:43px;bottom:82px;height:86px;border-top:9px solid #77dfff;border-radius:120px 120px 0 0}.car-base{position:absolute;left:62px;right:62px;bottom:72px;height:9px;background:#77dfff;border-radius:99px}.wheel{position:absolute;bottom:46px;width:40px;height:40px;border-radius:50%;border:8px solid var(--gold);background:#173050}.wheel-left{left:86px}.wheel-right{right:86px}.visual-contact{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:13px 16px;border-radius:18px;background:rgba(255,255,255,.82);border:1px solid rgba(18,32,51,.1);box-shadow:0 12px 28px rgba(35,75,120,.08);font-weight:800;color:#17335a}.visual-contact span{white-space:nowrap}.contact-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:28px}.contact-card{padding:28px;border-radius:var(--radius);background:linear-gradient(180deg,#ffffff,#f8fbff);border:1px solid var(--line);box-shadow:var(--shadow)}.contact-list{display:grid;gap:14px}.contact-row{display:flex;gap:14px;align-items:flex-start;padding:16px;border-radius:18px;background:#fff;border:1px solid var(--line);box-shadow:0 10px 26px rgba(28,70,115,.07)}.contact-row b{display:block;color:#16283d}.contact-row span{color:var(--muted)}
.form{display:grid;gap:14px}.form label{display:grid;gap:7px;color:#1e344d;font-weight:800}.form input,.form textarea,.form select{width:100%;border:1px solid rgba(18,32,51,.16);background:#fff;border-radius:16px;padding:13px 14px;color:#122033;font:inherit;outline:none;transition:.2s}.form textarea{min-height:130px;resize:vertical}.form input:focus,.form textarea:focus,.form select:focus{border-color:rgba(39,199,255,.55);box-shadow:0 0 0 4px rgba(39,199,255,.12)}.honeypot{display:none!important}.form-status{display:none;margin-top:10px;padding:12px 14px;border-radius:14px;background:rgba(39,199,255,.12);border:1px solid rgba(39,199,255,.25);color:#0d5b95}.form-status.is-error{background:rgba(255,92,108,.12);border-color:rgba(255,92,108,.25)}
.map-box{margin-top:20px;border-radius:22px;overflow:hidden;border:1px solid var(--line);background:#eef6fd}.map-box img{width:100%;height:270px;object-fit:cover;filter:saturate(1.1)}.qr-box{margin-top:20px;padding:20px;border-radius:22px;background:#fff;border:1px solid var(--line);box-shadow:0 10px 26px rgba(28,70,115,.07)}.qr-box-head h3{margin:0 0 6px;color:#16283d}.qr-box-head p{margin:0;color:var(--muted)}.qr-box-image{margin-top:16px;display:flex;justify-content:center}.qr-box-image img{width:min(100%,260px);height:auto;border-radius:18px;border:1px solid var(--line);background:#fff;padding:10px;box-shadow:0 10px 26px rgba(28,70,115,.08)}.site-footer small{color:var(--muted)}
.quick-contact{position:fixed;right:22px;bottom:22px;z-index:80}.quick-main{position:relative;width:66px;height:66px;border-radius:24px;border:0;color:#06111d;background:linear-gradient(135deg,var(--gold),#fff1bb);display:grid;place-items:center;font-size:26px;box-shadow:0 20px 50px rgba(80,92,120,.24);cursor:pointer}.quick-pulse{position:absolute;inset:-9px;border:1px solid rgba(246,196,83,.48);border-radius:30px;animation:pulse 1.8s ease-out infinite}.quick-icon{position:relative;z-index:2}@keyframes pulse{0%{transform:scale(.85);opacity:.8}100%{transform:scale(1.28);opacity:0}}.quick-list{position:absolute;right:0;bottom:82px;display:grid;gap:10px;opacity:0;visibility:hidden;transform:translateY(12px) scale(.98);transition:.25s ease}.quick-contact.is-open .quick-list{opacity:1;visibility:visible;transform:none}.quick-item{min-width:220px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:18px;background:rgba(255,255,255,.96);border:1px solid rgba(18,32,51,.12);box-shadow:0 16px 38px rgba(30,80,130,.16);backdrop-filter:blur(14px)}.quick-item span{font-size:12px;color:var(--muted)}.quick-item strong{font-size:14px}.quick-item.phone{border-color:rgba(39,199,255,.42)}.quick-item.line{border-color:rgba(47,215,139,.42)}.quick-item.mail{border-color:rgba(246,196,83,.42)}.quick-item.map{border-color:rgba(255,92,108,.42)}
.site-footer{padding:60px 0 24px;background:#eef5fb;border-top:1px solid var(--line)}.back-to-top{font-weight:800;color:#0d5fc2}.back-to-top:hover{text-decoration:underline}.footer-grid{display:grid;grid-template-columns:1.1fr .9fr 1fr;gap:34px}.footer-brand{font-size:28px;font-weight:900;letter-spacing:.12em;color:#16283d}.site-footer h3{margin:0 0 14px;color:#16283d}.site-footer p,.site-footer li{color:var(--muted)}.site-footer ul{margin:0;padding-left:20px}.small-note{font-size:12px;opacity:.9}.footer-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:26px;margin-top:26px;border-top:1px solid var(--line);color:var(--muted);font-size:14px}
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}.reveal.is-visible{opacity:1;transform:none}.delay-1{transition-delay:.08s}.delay-2{transition-delay:.16s}.delay-3{transition-delay:.24s}.delay-4{transition-delay:.32s}
@media (max-width:1000px){.hero-inner,.split,.contact-grid{grid-template-columns:1fr}.hero{min-height:auto}.hero-card{transform:none;animation:none}.grid-4{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(2,1fr)}.cta-band{grid-template-columns:1fr}.cta-actions{justify-content:flex-start}.footer-grid{grid-template-columns:1fr 1fr}.main-nav{position:fixed;top:116px;left:18px;right:18px;display:grid;background:rgba(255,255,255,.98);border:1px solid var(--line);border-radius:24px;padding:14px;box-shadow:var(--shadow);opacity:0;visibility:hidden;transform:translateY(-10px);transition:.22s}.main-nav.is-open{opacity:1;visibility:visible;transform:none}.main-nav a{padding:12px 14px}.nav-toggle{display:block}}
@media (max-width:640px){.container{width:min(100% - 26px,1180px)}.topbar{justify-content:flex-start;gap:10px;padding:8px 0}.topbar span{width:100%;margin:0}.nav-wrap{min-height:70px}.brand-mark{width:44px;height:44px}.brand-text strong{font-size:19px}.brand-text em{font-size:11px}.hero-inner{padding:54px 0}.hero-points,.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}.hero-card img,.split .media img{height:280px}.split .media-fit{padding:10px}.split .media-fit img{height:280px}.service-visual{min-height:auto;padding:22px}.visual-brand strong{font-size:25px}.visual-mark{width:52px;height:52px;border-radius:18px;font-size:28px}.visual-content{grid-template-columns:1fr}.visual-car{height:190px}.visual-contact{display:grid}.section{padding:70px 0}.card-body{padding:20px}.image-card img{height:210px}.cta-band{padding:28px;border-radius:26px}.btn{width:100%;padding:13px 16px}.footer-grid{grid-template-columns:1fr}.quick-contact{right:14px;bottom:14px}.quick-main{width:60px;height:60px;border-radius:21px}.quick-list{bottom:74px}.quick-item{min-width:205px}.contact-card{padding:20px}.page-hero{padding:52px 0 38px}}
@media (prefers-reduced-motion:reduce){*,*:before,*:after{animation:none!important;transition:none!important;scroll-behavior:auto!important}.reveal{opacity:1;transform:none}}


/* v8 luxury enhancements */
.hero-card,.service-visual,.cta-band,.luxury-contact-main,.line-qr-panel,.promo-card{transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease;will-change:transform}
.hero-card::after,.service-visual::before,.cta-band::after,.luxury-contact-main::after,.line-qr-panel::after,.promo-card::after{content:"";position:absolute;pointer-events:none}
.hero-card,.service-visual,.cta-band,.luxury-contact-main,.line-qr-panel,.promo-card{position:relative;overflow:hidden}
.hero-card::after,.luxury-contact-main::after,.line-qr-panel::after,.promo-card::after{inset:auto -120% 0 auto;width:70%;height:180%;background:linear-gradient(115deg,rgba(255,255,255,0),rgba(255,255,255,.28),rgba(255,255,255,0));transform:rotate(12deg);animation:luxShine 7s ease-in-out infinite}
@keyframes luxShine{0%,100%{transform:translateX(0) rotate(12deg);opacity:0}15%{opacity:.0}35%{opacity:.8}55%{transform:translateX(-260%) rotate(12deg);opacity:0}}
@keyframes floatGentle{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.quick-contact{display:flex;flex-direction:column;align-items:flex-end;gap:10px}
.quick-label{padding:8px 14px;border-radius:999px;background:linear-gradient(135deg,#17335a,#0d5fc2);color:#fff;font-size:12px;font-weight:800;letter-spacing:.08em;box-shadow:0 14px 28px rgba(18,44,78,.22)}
.quick-main{background:linear-gradient(135deg,#fff3b8,var(--gold),#ffd871)}
.quick-item.phone-alt{border-color:rgba(13,95,194,.35)}
.quick-list{gap:12px}
.quick-item{min-width:240px}
.quick-item strong{color:#17335a}
.quick-item:hover{transform:translateY(-2px);box-shadow:0 20px 44px rgba(30,80,130,.18)}
.quick-contact-section{padding-top:20px}
.luxury-contact-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:26px;align-items:stretch}
.luxury-contact-main{padding:30px;border-radius:32px;background:linear-gradient(135deg,rgba(12,35,62,.98),rgba(18,55,97,.96) 50%,rgba(14,96,194,.92));border:1px solid rgba(255,255,255,.16);box-shadow:0 24px 64px rgba(20,48,88,.24);color:#fff;animation:floatGentle 8s ease-in-out infinite}
.contact-badge{display:inline-flex;padding:8px 14px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);font-size:12px;font-weight:800;letter-spacing:.05em;color:#dff1ff}
.luxury-headline h3{margin:14px 0 10px;font-size:clamp(26px,3vw,38px);line-height:1.16;color:#fff}
.luxury-headline p{margin:0;color:rgba(255,255,255,.82)}
.phone-highlight-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:22px}
.contact-chip{display:flex;flex-direction:column;gap:6px;padding:20px;border-radius:24px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.16);backdrop-filter:blur(6px);box-shadow:0 14px 30px rgba(8,20,37,.18)}
.contact-chip span{font-size:12px;color:#cae8ff;font-weight:700;letter-spacing:.04em}
.contact-chip strong{font-size:28px;line-height:1.05;color:#fff;font-family:var(--font-display)}
.contact-chip small{color:rgba(255,255,255,.72)}
.contact-chip.primary{background:linear-gradient(135deg,rgba(246,196,83,.20),rgba(255,255,255,.10))}
.contact-chip.line{background:linear-gradient(135deg,rgba(47,215,139,.18),rgba(255,255,255,.10))}
.contact-chip.secondary{background:linear-gradient(135deg,rgba(39,199,255,.18),rgba(255,255,255,.10))}
.contact-cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}
.line-qr-panel{padding:26px;border-radius:32px;background:linear-gradient(180deg,#ffffff,#f5fbff);border:1px solid rgba(18,32,51,.11);box-shadow:0 24px 64px rgba(20,48,88,.14);animation:floatGentle 8s ease-in-out infinite 1.2s}
.line-qr-head h3{margin:6px 0 8px;color:#15283f;font-size:28px;line-height:1.2}
.line-qr-head p{margin:0;color:#53667b}
.line-qr-image-wrap{position:relative;margin-top:18px;padding:18px;border-radius:28px;background:radial-gradient(circle at 50% 30%,rgba(47,215,139,.15),transparent 55%),linear-gradient(180deg,#ffffff,#eef7ff);border:1px solid var(--line);display:flex;justify-content:center}
.line-qr-image-wrap img{width:min(100%,280px);height:auto;border-radius:22px;box-shadow:0 18px 38px rgba(22,60,102,.16);background:#fff}
.line-qr-btn{width:100%;margin-top:18px;justify-content:center}
.showcase-section{position:relative}
.promo-gallery{display:grid;grid-template-columns:1.2fr .8fr;gap:22px}
.promo-card{border-radius:30px;background:linear-gradient(180deg,#ffffff,#f8fbff);border:1px solid var(--line);box-shadow:0 18px 42px rgba(24,57,98,.10)}
.promo-card-image{padding:14px 14px 0}
.promo-card img{width:100%;height:auto;display:block;border-radius:24px}
.promo-wide .promo-card-image img{aspect-ratio:16/9;object-fit:cover}
.promo-square .promo-card-image img{aspect-ratio:1/1;object-fit:cover;background:#fff}
.promo-card-body{padding:18px 20px 24px}
.promo-label{display:inline-flex;padding:7px 12px;border-radius:999px;background:rgba(13,95,194,.08);color:#0d5fc2;font-size:12px;font-weight:800;letter-spacing:.05em}
.promo-card h3{margin:12px 0 8px;color:#16283d;font-size:24px;line-height:1.25}
.promo-card p{margin:0;color:#55677b}
.cta-band{background:linear-gradient(135deg,rgba(34,103,255,.12),rgba(39,199,255,.14),rgba(246,196,83,.18));box-shadow:0 20px 50px rgba(20,48,88,.12)}
.cta-band:after{inset:auto -140% -60% auto;width:80%;height:220%;background:linear-gradient(115deg,rgba(255,255,255,0),rgba(255,255,255,.22),rgba(255,255,255,0));transform:rotate(10deg);animation:luxShine 9s ease-in-out infinite}
@media (max-width:1000px){.luxury-contact-grid,.promo-gallery{grid-template-columns:1fr}.phone-highlight-grid{grid-template-columns:1fr}.contact-chip strong{font-size:24px}}
@media (max-width:640px){.luxury-contact-main,.line-qr-panel{padding:22px;border-radius:26px}.contact-cta-row .btn{width:100%}.quick-label{font-size:11px;padding:7px 12px}.quick-item{min-width:210px}.line-qr-head h3{font-size:24px}.promo-card h3{font-size:22px}}


/* v9 premium + SEO landing enhancements */
.premium-intro-section{padding-top:10px}
.premium-intro{display:grid;grid-template-columns:1.15fr .85fr;gap:24px;padding:32px;border-radius:34px;background:linear-gradient(135deg,#fffef8,rgba(255,255,255,.95) 45%,rgba(241,248,255,.96));border:1px solid rgba(214,175,64,.24);box-shadow:0 24px 60px rgba(18,45,77,.10);position:relative;overflow:hidden}
.premium-intro:before{content:"";position:absolute;inset:-30% auto auto -10%;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(246,196,83,.18),transparent 68%)}
.premium-intro:after{content:"";position:absolute;right:-80px;bottom:-90px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(39,199,255,.16),transparent 70%)}
.premium-intro-copy,.premium-intro-stats{position:relative;z-index:1}
.premium-intro-copy h2{margin:8px 0 12px;color:#16283d;font-size:clamp(28px,3vw,42px);line-height:1.18}
.premium-intro-copy p{margin:0;color:#55677b}
.premium-intro-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;align-content:center}
.premium-stat{padding:20px;border-radius:24px;background:rgba(255,255,255,.86);border:1px solid rgba(18,32,51,.09);box-shadow:0 14px 34px rgba(18,45,77,.08)}
.premium-stat strong{display:block;font-size:26px;line-height:1.1;color:#17335a;font-family:var(--font-display)}
.premium-stat span{display:block;margin-top:6px;color:#647488;font-weight:700}
.alt-soft{background:linear-gradient(180deg,#f9fbfe,#f2f8ff)}
.review-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.review-card{padding:24px;border-radius:28px;background:linear-gradient(180deg,#ffffff,#f7fbff);border:1px solid rgba(18,32,51,.08);box-shadow:0 16px 40px rgba(18,45,77,.08)}
.review-card h3{margin:12px 0 8px;color:#16283d;font-size:22px;line-height:1.28}
.review-card p{margin:0;color:#55677b}
.review-mark{display:inline-grid;place-items:center;width:48px;height:48px;border-radius:16px;background:linear-gradient(135deg,#17335a,#0d5fc2);color:#fff;font-weight:900;box-shadow:0 14px 28px rgba(18,44,78,.18)}
.faq-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.faq-card{padding:24px;border-radius:26px;background:linear-gradient(180deg,#ffffff,#f8fbff);border:1px solid rgba(18,32,51,.08);box-shadow:0 16px 40px rgba(18,45,77,.08)}
.faq-card h3{margin:0 0 10px;color:#16283d;font-size:21px;line-height:1.3}
.faq-card p{margin:0;color:#55677b}
@media (max-width:1000px){.premium-intro,.review-grid,.faq-grid{grid-template-columns:1fr 1fr}.premium-intro{grid-template-columns:1fr}}
@media (max-width:640px){.premium-intro,.review-grid,.faq-grid{grid-template-columns:1fr}.premium-intro{padding:24px;border-radius:26px}.premium-intro-copy h2{font-size:26px}.premium-stat strong{font-size:22px}.review-card,.faq-card{padding:20px}}


/* v12 banner + brand spotlight refinements */
.hero-banner-card{animation:floatCard 6.4s ease-in-out infinite;transform:perspective(900px) rotateY(-3deg)}
.hero-banner-frame{position:relative;overflow:hidden}
.hero-banner-frame img{height:430px;object-fit:cover;transform:scale(1.01);transition:transform .8s ease, filter .8s ease;filter:saturate(1.06) contrast(1.02)}
.hero-banner-card:hover .hero-banner-frame img{transform:scale(1.05);filter:saturate(1.12) contrast(1.04)}
.hero-banner-overlay{position:absolute;left:18px;right:18px;bottom:18px;display:flex;align-items:flex-end;justify-content:space-between;gap:14px;padding:16px 18px;border-radius:24px;background:linear-gradient(135deg,rgba(10,22,38,.78),rgba(13,95,194,.34));backdrop-filter:blur(7px);box-shadow:0 12px 28px rgba(7,20,38,.22)}
.hero-banner-overlay strong{color:#fff;font-family:var(--font-display);font-size:18px;line-height:1.3;text-shadow:0 2px 8px rgba(0,0,0,.2)}
.hero-banner-badge{display:inline-flex;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);color:#fff;font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase}
.hero-banner-copy h2{font-size:30px}
.brand-spotlight-section{padding-top:28px}
.brand-spotlight-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:28px;align-items:stretch}
.brand-poster-card,.brand-copy-panel{position:relative;overflow:hidden;border-radius:34px}
.brand-poster-card{padding:26px;background:linear-gradient(180deg,#ffffff,#f7fbff);border:1px solid rgba(18,32,51,.10);box-shadow:0 22px 58px rgba(18,45,77,.10)}
.brand-poster-card:before,.brand-copy-panel:before{content:"";position:absolute;inset:auto -120% 0 auto;width:70%;height:180%;background:linear-gradient(115deg,rgba(255,255,255,0),rgba(255,255,255,.24),rgba(255,255,255,0));transform:rotate(12deg);animation:luxShine 8s ease-in-out infinite;pointer-events:none}
.brand-poster-head h2{margin:8px 0 0;color:#16283d;font-size:34px;line-height:1.18}
.brand-poster-image{margin-top:20px;padding:18px;border-radius:28px;background:radial-gradient(circle at 50% 14%,rgba(246,196,83,.16),transparent 40%),linear-gradient(180deg,#ffffff,#eef6ff);border:1px solid rgba(18,32,51,.09)}
.brand-poster-image img{width:100%;border-radius:24px;aspect-ratio:1/1;object-fit:cover;box-shadow:0 20px 46px rgba(18,45,77,.12)}
.brand-copy-panel{padding:34px;background:linear-gradient(135deg,#123459,#143f70 48%,#0d5fc2);border:1px solid rgba(255,255,255,.12);box-shadow:0 24px 64px rgba(18,45,77,.18);color:#fff;animation:floatGentle 8.5s ease-in-out infinite 0.8s}
.brand-copy-panel .eyebrow{color:#f8d37a}
.brand-copy-panel h2{margin:8px 0 14px;color:#fff;font-size:clamp(30px,3.4vw,44px);line-height:1.16}
.brand-copy-panel p{margin:0;color:rgba(255,255,255,.84)}
.brand-note-list{display:grid;gap:14px;margin-top:22px}
.brand-note{padding:18px 20px;border-radius:24px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.16);box-shadow:0 16px 32px rgba(8,20,37,.16)}
.brand-note strong{display:block;font-family:var(--font-display);font-size:20px;color:#fff;margin-bottom:4px}
.brand-note span{display:block;color:rgba(255,255,255,.78)}
.brand-copy-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
@media (max-width:1000px){.brand-spotlight-grid{grid-template-columns:1fr}.brand-poster-head h2{font-size:30px}}
@media (max-width:640px){.hero-banner-frame img{height:300px}.hero-banner-overlay{left:12px;right:12px;bottom:12px;padding:12px 14px;flex-direction:column;align-items:flex-start}.hero-banner-overlay strong{font-size:15px}.hero-banner-copy h2{font-size:26px}.brand-poster-card,.brand-copy-panel{border-radius:26px}.brand-copy-panel{padding:24px}.brand-note{padding:16px 18px}.brand-copy-actions .btn{width:100%}}


/* v13 mobile refinement, premium banner sizing, contact icons */
.hero{min-height:760px}
.hero-inner{gap:56px}
.hero-banner-card{box-shadow:0 28px 80px rgba(18,45,77,.22),0 0 0 1px rgba(246,196,83,.18)}
.hero-banner-card:before{content:"";position:absolute;inset:-2px;border-radius:var(--radius);background:linear-gradient(135deg,rgba(246,196,83,.52),rgba(39,199,255,.12),rgba(13,95,194,.28));opacity:.38;filter:blur(16px);z-index:-1;animation:premiumAura 6s ease-in-out infinite}
@keyframes premiumAura{0%,100%{opacity:.28;transform:scale(.985)}50%{opacity:.55;transform:scale(1.015)}}
.hero-banner-frame img{height:480px;object-fit:cover;object-position:center center}
.hero-banner-frame:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 70% 18%,rgba(255,231,150,.20),transparent 30%),linear-gradient(180deg,rgba(255,255,255,0),rgba(6,17,29,.22));pointer-events:none}
.hero-banner-overlay{border:1px solid rgba(246,196,83,.22);box-shadow:0 16px 38px rgba(7,20,38,.30),inset 0 0 0 1px rgba(255,255,255,.08)}
.hero-banner-badge{background:linear-gradient(135deg,rgba(246,196,83,.26),rgba(255,255,255,.12));border-color:rgba(246,196,83,.34)}
.brand-poster-card,.brand-copy-panel{box-shadow:0 26px 70px rgba(18,45,77,.14)}
.brand-poster-image{box-shadow:inset 0 0 0 1px rgba(246,196,83,.12),0 22px 50px rgba(18,45,77,.08)}
.brand-poster-image img{object-position:center center;transition:transform .7s ease, filter .7s ease}
.brand-poster-card:hover .brand-poster-image img{transform:scale(1.035);filter:saturate(1.08) contrast(1.02)}
.quick-list{gap:12px}
.quick-item{justify-content:flex-start;min-width:260px;padding:13px 15px 13px 13px;position:relative;overflow:hidden;border-radius:20px;transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease}
.quick-item:after{content:"›";margin-left:auto;font-size:24px;line-height:1;color:rgba(23,51,90,.32)}
.quick-channel-icon{width:42px;height:42px;min-width:42px;border-radius:15px;display:grid;place-items:center;font-weight:900;font-size:18px;font-family:var(--font-display);box-shadow:0 10px 24px rgba(18,45,77,.12)}
.quick-channel-text{display:grid;gap:0;line-height:1.25;text-align:left}
.quick-channel-text span{font-size:12px;color:var(--muted);font-weight:700}
.quick-channel-text strong{font-size:15px;color:#17335a;font-family:var(--font-display)}
.quick-item.phone .quick-channel-icon{background:linear-gradient(135deg,#dff8ff,#27c7ff);color:#08335a}
.quick-item.line .quick-channel-icon{background:linear-gradient(135deg,#e5fff0,#2fd78b);color:#083b22;font-size:12px;letter-spacing:.02em}
.quick-item.phone-alt .quick-channel-icon{background:linear-gradient(135deg,#eef4ff,#77a7ff);color:#102c60}
.quick-item.mail .quick-channel-icon{background:linear-gradient(135deg,#fff6d9,#f6c453);color:#5b3b02}
.quick-item.map .quick-channel-icon{background:linear-gradient(135deg,#ffe9ec,#ff5c6c);color:#5f0914}
.quick-item:hover{transform:translateY(-3px);box-shadow:0 22px 48px rgba(30,80,130,.20)}
.quick-contact.is-open .quick-item{animation:quickPop .28s ease both}
.quick-contact.is-open .quick-item:nth-child(2){animation-delay:.03s}.quick-contact.is-open .quick-item:nth-child(3){animation-delay:.06s}.quick-contact.is-open .quick-item:nth-child(4){animation-delay:.09s}.quick-contact.is-open .quick-item:nth-child(5){animation-delay:.12s}
@keyframes quickPop{from{opacity:0;transform:translateY(8px) scale(.96)}to{opacity:1;transform:none}}
@media (max-width:1100px){.hero{min-height:auto}.hero-inner{grid-template-columns:1fr;gap:34px;padding:62px 0}.hero-copy{max-width:920px}.hero-banner-frame img{height:420px}.hero-card{transform:none}.hero-card:hover{transform:none}}
@media (max-width:760px){.topbar a{font-size:13px}.hero{background:radial-gradient(circle at 18% 10%,rgba(39,199,255,.16),transparent 34%),linear-gradient(180deg,#ffffff,#eef7ff)}.hero-inner{padding:42px 0 50px;gap:26px}.hero h1{font-size:clamp(23px,7.2vw,34px);line-height:1.22;margin-top:14px}.lead{font-size:16px;line-height:1.75;margin-bottom:22px}.hero-actions{gap:10px;margin-bottom:24px}.hero-points{gap:10px}.point{padding:13px 14px}.hero-banner-frame img{height:300px;object-position:center center}.hero-banner-overlay{left:10px;right:10px;bottom:10px;border-radius:18px;padding:10px 12px}.hero-banner-badge{font-size:10px;padding:6px 9px}.hero-banner-overlay strong{font-size:13px}.hero-banner-copy h2{font-size:23px;line-height:1.25}.hero-card-content{padding:18px}.badge-grid{gap:9px}.mini-badge{padding:10px;font-size:13px}.brand-spotlight-section{padding-top:56px}.brand-poster-card{padding:18px}.brand-poster-head h2,.brand-copy-panel h2{font-size:25px}.brand-poster-image{padding:10px;margin-top:14px}.brand-copy-panel{padding:22px}.brand-note strong{font-size:17px}.brand-note span{font-size:14px}.luxury-contact-main,.line-qr-panel{box-shadow:0 18px 44px rgba(18,45,77,.13)}.phone-highlight-grid{gap:12px}.contact-chip{padding:16px}.contact-chip strong{font-size:21px}.quick-list{bottom:72px;right:0}.quick-item{min-width:min(82vw,310px);padding:12px 13px}.quick-channel-icon{width:38px;height:38px;min-width:38px;border-radius:13px}.quick-channel-text strong{font-size:14px}.quick-label{display:none}.section{padding:58px 0}.section-head{margin-bottom:28px}.section h2{font-size:clamp(25px,7vw,32px)}.section-head p{font-size:16px;line-height:1.75}.review-grid,.faq-grid,.premium-intro-stats{gap:13px}.review-card,.faq-card,.premium-stat{border-radius:22px;padding:18px}.cta-band{gap:18px}}
@media (max-width:420px){.hero-banner-frame img{height:245px}.hero-banner-overlay strong{display:none}.hero-banner-card .hero-card-content p{font-size:14px}.brand-copy-actions{gap:9px}.line-qr-image-wrap img{width:min(100%,230px)}.quick-contact{right:12px;bottom:12px}.quick-main{width:58px;height:58px}.quick-item{min-width:calc(100vw - 34px)}}


/* v14 layout refinement: full-width top banner + side brand image */
.hero-layout{display:grid;grid-template-columns:1fr;gap:28px;align-items:stretch;padding:72px 0}
.hero-top-banner{width:100%;transform:none!important;animation:floatGentle 8s ease-in-out infinite;box-shadow:0 30px 82px rgba(18,45,77,.20),0 0 0 1px rgba(246,196,83,.20)}
.hero-top-banner .hero-banner-frame{padding:14px;background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(245,250,255,.88))}
.hero-top-banner .hero-banner-frame img{width:100%;height:auto;min-height:0;max-height:none;object-fit:contain;object-position:center center;border-radius:24px;box-shadow:0 18px 48px rgba(10,26,46,.18)}
.hero-top-banner .hero-banner-overlay,.hero-top-banner .hero-card-content{display:none}
.hero-lower-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:28px;align-items:start}
.hero-lower-grid .hero-copy{max-width:none}
.brand-poster-side{padding:24px;background:linear-gradient(180deg,#ffffff,#f7fbff);box-shadow:0 24px 64px rgba(18,45,77,.12)}
.brand-poster-side .brand-poster-head h2{font-size:30px}
.brand-poster-image-full{padding:14px;margin-top:16px}
.brand-poster-image-full img{width:100%;height:auto;aspect-ratio:auto;object-fit:contain;object-position:center center;border-radius:22px;box-shadow:0 18px 44px rgba(18,45,77,.12)}
@media (min-width:1101px){.hero{min-height:auto}.hero-top-banner .hero-banner-frame img{min-height:440px}}
@media (max-width:1100px){.hero-layout{padding:58px 0}.hero-lower-grid{grid-template-columns:1fr;gap:24px}.hero-top-banner .hero-banner-frame img{min-height:0}}
@media (max-width:760px){.hero-layout{padding:42px 0 48px;gap:22px}.hero-top-banner .hero-banner-frame{padding:10px}.hero-top-banner .hero-banner-frame img{border-radius:18px}.brand-poster-side{padding:18px}.brand-poster-side .brand-poster-head h2{font-size:24px}.brand-poster-image-full{padding:10px;margin-top:12px}}
@media (max-width:420px){.hero-top-banner .hero-banner-frame{padding:8px}.brand-poster-image-full img{border-radius:18px}}

/* v15 remove brand heading above second image */
.brand-poster-clean{padding:18px}
.brand-poster-clean .brand-poster-image-full{margin-top:0}
@media (max-width:760px){
  .brand-poster-clean{padding:14px}
  .brand-poster-clean .brand-poster-image-full{margin-top:0;padding:8px}
}


/* Contact form popup status */
body.has-form-popup{overflow:hidden}
.form-popup{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;padding:22px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .22s ease,visibility .22s ease}
.form-popup.is-open{opacity:1;visibility:visible;pointer-events:auto}
.form-popup-backdrop{position:absolute;inset:0;background:rgba(8,18,32,.52);backdrop-filter:blur(8px)}
.form-popup-card{position:relative;z-index:2;width:min(100%,430px);padding:34px 28px 28px;border-radius:30px;background:linear-gradient(180deg,#ffffff,#f7fbff);border:1px solid rgba(18,32,51,.12);box-shadow:0 30px 90px rgba(10,28,52,.34);text-align:center;transform:translateY(12px) scale(.96);transition:transform .24s ease;overflow:hidden}
.form-popup.is-open .form-popup-card{transform:none}
.form-popup-card:before{content:"";position:absolute;inset:auto -40% -46% -40%;height:150px;background:radial-gradient(circle,rgba(246,196,83,.22),transparent 68%);pointer-events:none}
.form-popup-icon{position:relative;width:76px;height:76px;margin:0 auto 18px;border-radius:26px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(39,199,255,.16),rgba(246,196,83,.18));border:1px solid rgba(18,32,51,.10);box-shadow:0 16px 34px rgba(28,70,115,.12)}
.popup-spinner{display:none;width:34px;height:34px;border-radius:50%;border:4px solid rgba(13,95,194,.16);border-top-color:var(--blue2);animation:popupSpin .8s linear infinite}
.popup-mark{display:none;font-size:38px;line-height:1;font-weight:900;font-family:var(--font-display)}
.form-popup.is-loading .popup-spinner{display:block}
.form-popup.is-success .popup-mark,.form-popup.is-error .popup-mark{display:block}
.form-popup.is-success .popup-mark:before{content:"✓";color:var(--green)}
.form-popup.is-error .popup-mark:before{content:"!";color:var(--red)}
.form-popup-card h3{position:relative;margin:0 0 8px;color:#16283d;font-size:28px;line-height:1.22}
.form-popup-card p{position:relative;margin:0;color:var(--muted);font-size:16px;line-height:1.75}
.form-popup-close{position:relative;margin-top:22px;min-width:140px}
.form button[disabled]{opacity:.72;cursor:wait;transform:none!important}
@keyframes popupSpin{to{transform:rotate(360deg)}}
@media (max-width:640px){.form-popup{padding:16px}.form-popup-card{padding:30px 22px 24px;border-radius:26px}.form-popup-icon{width:68px;height:68px;border-radius:23px}.form-popup-card h3{font-size:24px}.form-popup-close{width:100%}}


/* Footer credit + desktop contact card alignment fix */
.footer-bottom{align-items:flex-start}
.footer-copyright{display:grid;gap:4px}
.developer-credit{display:block;font-size:13px;color:var(--muted)}
.developer-credit a{color:#0d5fc2;font-weight:800}
.developer-credit a:hover{text-decoration:underline}

.phone-highlight-grid{grid-template-columns:repeat(3,minmax(0,1fr));overflow:visible}
.contact-chip{min-width:0;overflow:hidden}
.contact-chip strong{font-size:clamp(20px,1.55vw,26px);white-space:nowrap;letter-spacing:-.02em}
.contact-chip small{display:block;line-height:1.45}
.luxury-contact-main{overflow:hidden}

@media (min-width:1001px) and (max-width:1250px){
  .phone-highlight-grid{gap:12px}
  .contact-chip{padding:16px}
  .contact-chip strong{font-size:21px}
}

@media (max-width:640px){
  .footer-bottom{display:grid;gap:12px}
  .footer-copyright{gap:3px}
}


/* v2: fix contact chips overflow and force footer credit to new line */
.footer-bottom{align-items:flex-start}
.footer-copyright{display:flex;flex-direction:column;gap:4px;line-height:1.6}
.developer-credit{display:block;width:100%;font-size:13px;color:var(--muted);margin-top:2px}
.developer-credit a{color:#0d5fc2;font-weight:800}
.developer-credit a:hover{text-decoration:underline}

/* Desktop contact card: prevent third phone box from being cut */
.luxury-contact-main{overflow:hidden}
.phone-highlight-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  width:100%;
  max-width:100%;
}
.contact-chip{
  min-width:0;
  max-width:100%;
  overflow:hidden;
  padding:16px 14px;
}
.contact-chip strong{
  display:block;
  max-width:100%;
  font-size:clamp(18px,1.35vw,24px);
  line-height:1.1;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  letter-spacing:-.04em;
}
.contact-chip small{
  display:block;
  font-size:13px;
  line-height:1.45;
  overflow-wrap:anywhere;
}

@media (max-width:1250px){
  .phone-highlight-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .phone-highlight-grid .contact-chip:nth-child(3){grid-column:1 / -1}
  .contact-chip strong{font-size:24px;letter-spacing:-.03em}
}

@media (max-width:760px){
  .phone-highlight-grid{grid-template-columns:1fr}
  .phone-highlight-grid .contact-chip:nth-child(3){grid-column:auto}
  .contact-chip strong{font-size:23px}
  .footer-bottom{display:grid;gap:12px}
}


/* FINAL FIX 2026-05-19: contact chips overflow + footer credit newline */
.footer-bottom{
  display:flex !important;
  align-items:flex-start !important;
  justify-content:space-between !important;
  gap:16px !important;
  flex-wrap:wrap !important;
}
.footer-copyright{
  display:block !important;
  line-height:1.65 !important;
}
.footer-copyright .developer-credit{
  display:inline-block !important;
  margin-top:2px !important;
  font-size:13px !important;
  color:var(--muted) !important;
}
.footer-copyright .developer-credit a{
  color:#0d5fc2 !important;
  font-weight:800 !important;
}
.footer-copyright .developer-credit a:hover{
  text-decoration:underline !important;
}

/* Main quick contact card: never allow the third phone box to be clipped */
.luxury-contact-main{
  overflow:visible !important;
}
.luxury-contact-grid{
  grid-template-columns:1fr !important;
  gap:24px !important;
}
.luxury-contact-grid .line-qr-panel{
  max-width:560px !important;
  width:100% !important;
  margin:0 auto !important;
}
.phone-highlight-grid{
  display:grid !important;
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  gap:14px !important;
  width:100% !important;
  max-width:100% !important;
  overflow:visible !important;
}
.phone-highlight-grid .contact-chip:nth-child(3){
  grid-column:1 / -1 !important;
}
.contact-chip{
  min-width:0 !important;
  max-width:100% !important;
  overflow:visible !important;
  padding:18px 20px !important;
}
.contact-chip strong{
  display:block !important;
  max-width:100% !important;
  white-space:normal !important;
  overflow:visible !important;
  text-overflow:clip !important;
  word-break:keep-all !important;
  overflow-wrap:normal !important;
  font-size:clamp(22px,2vw,28px) !important;
  line-height:1.18 !important;
  letter-spacing:-.025em !important;
}
.contact-chip small{
  display:block !important;
  line-height:1.45 !important;
  white-space:normal !important;
  overflow:visible !important;
}
@media (max-width:760px){
  .footer-bottom{
    display:grid !important;
    gap:12px !important;
  }
  .phone-highlight-grid{
    grid-template-columns:1fr !important;
  }
  .phone-highlight-grid .contact-chip:nth-child(3){
    grid-column:auto !important;
  }
  .contact-chip strong{
    font-size:24px !important;
  }
}


/* Hide extra phone card in main contact block */
.phone-highlight-grid{
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
}
.phone-highlight-grid .contact-chip.secondary{
  display:none !important;
}
@media (max-width:760px){
  .phone-highlight-grid{
    grid-template-columns:1fr !important;
  }
}
