/* =====================================================================
   iMolecule Softech — Stylesheet (light edition)
   Bright, airy, modern agency/tech look. Brand blue + cyan on white,
   soft shadows, gradient accents, illustrations and line art.
   ===================================================================== */

:root{
  --bg:#f3f8fd; --bg-2:#e9f2fb; --surface:#ffffff;
  --ink:#0c2742; --text:#33506e; --muted:#6b86a6; --muted-2:#93a9c4;
  --brand:#0a6fb5; --brand-deep:#005a97; --cyan:#11bdec; --cyan-2:#5ad8f7;
  /* Warm multi-accent palette — blue stays the anchor; these rotate across cards */
  --coral:#ff6b5d;  --coral-soft:#fff0ed;
  --amber:#f5a524;  --amber-soft:#fff5e3;
  --violet:#7c5cff; --violet-soft:#efecff;
  --teal:#12c4a0;   --teal-soft:#e3faf3;
  --line:#d9e7f5; --line-soft:#e7f0fa;
  --radius:20px; --radius-sm:13px; --maxw:1180px;
  --grad:linear-gradient(120deg,#16c3ef 0%,#0a6fb5 42%,#7c5cff 100%);
  --grad-vivid:linear-gradient(120deg,#11bdec 0%,#7c5cff 45%,#ff6b5d 100%);
  --grad-soft:linear-gradient(135deg,#eafaff 0%,#e3f1fc 100%);
  --shadow:0 22px 48px -22px rgba(10,70,120,.28);
  --shadow-sm:0 10px 26px -14px rgba(10,70,120,.25);
  --glow:0 14px 34px -10px rgba(17,189,236,.5);
  --ff-display:'Sora',sans-serif; --ff-body:'Plus Jakarta Sans',sans-serif; --ff-mono:'JetBrains Mono',ui-monospace,monospace;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--ff-body);background:var(--bg);color:var(--text);line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
section{position:relative}

.wrap{width:min(var(--maxw),92vw);margin-inline:auto}
.eyebrow{font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--brand);display:inline-flex;align-items:center;gap:.6rem;font-weight:500}
.eyebrow::before{content:"";width:26px;height:2px;border-radius:2px;background:var(--grad)}
.section-pad{padding:clamp(4rem,8vw,7rem) 0}
h1,h2,h3,h4{font-family:var(--ff-display);font-weight:700;line-height:1.12;letter-spacing:-.02em;color:var(--ink)}
.h-accent{color:transparent;background:var(--grad-vivid);-webkit-background-clip:text;background-clip:text}
.section-head{max-width:660px;margin-bottom:3rem}
.section-head.center{margin-inline:auto;text-align:center}
.section-head h2{font-size:clamp(1.9rem,4.2vw,3rem);margin:1rem 0 .9rem}
.section-head p{color:var(--muted);font-size:1.06rem}
.lead{font-size:clamp(1.05rem,1.7vw,1.22rem);color:var(--muted)}

.btn{display:inline-flex;align-items:center;gap:.55rem;padding:.85rem 1.5rem;border-radius:999px;font-weight:600;font-size:.95rem;transition:transform .25s,box-shadow .3s,background .3s,color .3s,border-color .3s;white-space:nowrap}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--grad);color:#fff;box-shadow:var(--glow)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 40px -10px rgba(17,189,236,.65)}
.btn-ghost{border:1.5px solid var(--line);color:var(--brand);background:var(--surface)}
.btn-ghost:hover{border-color:var(--cyan);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.btn-light{background:rgba(255,255,255,.16);color:#fff;border:1.5px solid rgba(255,255,255,.4)}
.btn-light:hover{background:#fff;color:var(--brand);transform:translateY(-2px)}

.site-header{position:fixed;inset:0 0 auto 0;z-index:100;transition:background .35s,box-shadow .35s,padding .35s;padding:.4rem 0}
.site-header.scrolled{background:rgba(255,255,255,.85);backdrop-filter:blur(16px);box-shadow:0 6px 24px -16px rgba(10,70,120,.4)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:2rem;padding:.7rem 0}
.brand img{height:40px;width:auto}
.nav-links{display:flex;align-items:center;gap:1.9rem}
.nav-links a{font-size:.94rem;color:var(--text);font-weight:600;position:relative;transition:color .25s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-7px;height:2.5px;border-radius:3px;width:0;background:var(--grad);transition:width .3s}
.nav-links a:hover,.nav-links a.active{color:var(--brand)}
.nav-links a.active::after,.nav-links a:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:1rem}
.nav-phone{width:44px;height:44px;border-radius:50%;border:1.5px solid var(--line);background:var(--surface);color:var(--brand);display:grid;place-items:center;flex:none;transition:transform .25s,border-color .25s,background .25s,color .25s}
.nav-phone svg{width:20px;height:20px}
.nav-phone:hover{background:var(--grad);border-color:transparent;color:#fff;transform:translateY(-2px);box-shadow:var(--glow)}
.burger{display:none;width:44px;height:44px;border-radius:12px;border:1.5px solid var(--line);background:var(--surface);align-items:center;justify-content:center;flex-direction:column;gap:5px}
.burger span{width:18px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:.5;z-index:0;pointer-events:none}
.blob.c{background:radial-gradient(circle,#9fe3fb,transparent 70%)}
.blob.b{background:radial-gradient(circle,#d9c8ff,transparent 70%)}

.hero{padding-top:8.5rem;padding-bottom:4rem;overflow:hidden;background:radial-gradient(55% 65% at 88% 8%,#e7f6ff 0%,transparent 60%),radial-gradient(45% 55% at 2% 92%,#efeaff 0%,transparent 60%),radial-gradient(40% 45% at 60% 100%,#fff0ed 0%,transparent 55%)}
.hero-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:center;position:relative;z-index:2}
.hero h1{font-size:clamp(2.4rem,5.3vw,4rem);margin:1.3rem 0 1.2rem}
.hero .lead{max-width:38ch}
.hero-actions{display:flex;gap:1rem;margin-top:2rem;flex-wrap:wrap}
.hero-stats{display:flex;gap:2.4rem;margin-top:2.8rem;flex-wrap:wrap}
.stat .num{font-family:var(--ff-display);font-size:2rem;font-weight:800;color:var(--ink)}
.stat .num .plus{color:var(--coral)}
.hero-stats .stat:nth-child(2) .num .plus{color:var(--amber)}
.hero-stats .stat:nth-child(3) .num .plus{color:var(--violet)}
.hero-stats .stat:nth-child(4) .num .plus{color:var(--teal)}
.stat .lbl{font-size:.82rem;color:var(--muted)}
.hero-art{position:relative}
.hero-art img{width:100%;animation:float 6s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
@media(prefers-reduced-motion:reduce){.hero-art img{animation:none}}

.trust{background:linear-gradient(90deg,#ff6b5d,#f5a524);padding:1.15rem 0;overflow:hidden}
.trust-track{display:flex;gap:3rem;width:max-content;animation:slide 34s linear infinite}
.trust:hover .trust-track{animation-play-state:paused}
.trust span{font-family:var(--ff-mono);font-size:.88rem;color:#fff;letter-spacing:.04em;display:inline-flex;gap:3rem;align-items:center}
.trust span::after{content:"\25CF";color:rgba(255,255,255,.75);font-size:.5rem}
@keyframes slide{to{transform:translateX(-50%)}}

.page-banner{padding:9rem 0 3.5rem;background:radial-gradient(55% 80% at 90% 0%,#e3f4ff,transparent 60%),var(--bg);position:relative;overflow:hidden}
.crumbs{font-family:var(--ff-mono);font-size:.78rem;color:var(--muted);letter-spacing:.06em;margin-bottom:1rem}
.crumbs a:hover{color:var(--brand)}
.page-banner h1{font-size:clamp(2.1rem,4.6vw,3.2rem);margin-bottom:.8rem}
.page-banner p{color:var(--muted);font-size:1.08rem;max-width:60ch}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.3rem}

.svc-card{--accent:var(--brand);--accent-soft:var(--grad-soft);position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.7rem 1.5rem;transition:transform .35s,box-shadow .35s,border-color .35s;overflow:hidden}
.svc-card::after{content:"";position:absolute;left:0;top:0;height:5px;width:100%;background:var(--accent);transform:scaleX(1);transform-origin:left;transition:height .3s}
.svc-card:hover{transform:translateY(-6px);box-shadow:0 22px 48px -22px var(--accent);border-color:var(--accent)}
.svc-card:hover::after{height:7px}
.svc-ico{width:54px;height:54px;border-radius:15px;display:grid;place-items:center;margin-bottom:1.1rem;background:var(--accent);color:#fff;box-shadow:0 12px 26px -10px var(--accent);transition:.35s}
.svc-card:hover .svc-ico{transform:rotate(-6deg) scale(1.05)}
.svc-ico svg{width:27px;height:27px}
.svc-card h3{font-size:1.08rem;margin-bottom:.5rem;line-height:1.25}
.svc-card p{font-size:.92rem;color:var(--muted);margin-bottom:1rem}
.svc-tags{display:flex;flex-wrap:wrap;gap:.4rem}
.svc-tags span{font-family:var(--ff-mono);font-size:.68rem;color:var(--accent);background:var(--accent-soft);padding:.22rem .55rem;border-radius:7px}

/* Accent rotation — blue (default) → coral → amber → violet → teal, repeating.
   Shared across every repeated card so the page feels colorful but cohesive. */
.svc-card:nth-child(5n+2),.why-card:nth-child(5n+2),.step:nth-child(5n+2),.pf-card:nth-child(5n+2){--accent:var(--coral);--accent-soft:var(--coral-soft)}
.svc-card:nth-child(5n+3),.why-card:nth-child(5n+3),.step:nth-child(5n+3),.pf-card:nth-child(5n+3){--accent:var(--amber);--accent-soft:var(--amber-soft)}
.svc-card:nth-child(5n+4),.why-card:nth-child(5n+4),.step:nth-child(5n+4),.pf-card:nth-child(5n+4){--accent:var(--violet);--accent-soft:var(--violet-soft)}
.svc-card:nth-child(5n+5),.why-card:nth-child(5n+5),.step:nth-child(5n+5),.pf-card:nth-child(5n+5){--accent:var(--teal);--accent-soft:var(--teal-soft)}

.track-head{display:flex;align-items:center;gap:1rem;margin:.5rem 0 1.8rem;flex-wrap:wrap}
.track-head h2{font-size:clamp(1.6rem,3.2vw,2.2rem)}
.chip{font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;padding:.35rem .8rem;border-radius:999px;font-weight:500}
.chip.now{background:#e6f7ee;color:#0f9d58}
.chip.next{background:var(--grad-soft);color:var(--brand)}

.split-img{position:relative}
.split-img img{width:100%}
.about-points{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.8rem}
.about-points li{display:flex;gap:.7rem;align-items:flex-start;font-size:.95rem;color:var(--ink);font-weight:500}
.about-points li svg{width:22px;height:22px;color:#fff;background:var(--grad);border-radius:50%;padding:4px;flex:none}

.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-top:1rem}
.step{--accent:var(--brand);background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--accent);border-radius:var(--radius-sm);padding:1.5rem;position:relative;transition:.3s}
.step:hover{box-shadow:0 18px 36px -20px var(--accent);transform:translateY(-4px)}
.step .n{display:inline-grid;place-items:center;width:40px;height:40px;border-radius:11px;background:var(--accent);color:#fff;font-family:var(--ff-mono);font-size:1.15rem;font-weight:700;margin-bottom:.7rem}
.step h4{font-size:1.02rem;margin-bottom:.3rem}
.step p{font-size:.88rem;color:var(--muted)}

.why-card{--accent:var(--brand);--accent-soft:var(--grad-soft);background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;transition:.35s}
.why-card:hover{box-shadow:var(--shadow);transform:translateY(-5px)}
.why-card{border-top:4px solid var(--accent)}
.why-card .ic{width:50px;height:50px;border-radius:14px;background:var(--accent);color:#fff;box-shadow:0 12px 26px -10px var(--accent);display:grid;place-items:center;margin-bottom:1rem;transition:.35s}
.why-card:hover .ic{transform:rotate(-6deg) scale(1.05)}
.why-card .ic svg{width:25px;height:25px}
.why-card h3{font-size:1.1rem;margin-bottom:.45rem}
.why-card p{font-size:.92rem;color:var(--muted)}

.pf-filter{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:2rem}
.pf-chip{font-family:var(--ff-body);font-size:.86rem;font-weight:600;color:var(--text);background:var(--surface);border:1.5px solid var(--line);padding:.5rem 1rem;border-radius:999px;cursor:pointer;display:inline-flex;align-items:center;gap:.45rem;transition:.25s}
.pf-chip:hover{border-color:var(--cyan);color:var(--brand);transform:translateY(-2px)}
.pf-chip .n{font-family:var(--ff-mono);font-size:.7rem;color:var(--muted);background:var(--bg-2);padding:.05rem .4rem;border-radius:999px;transition:.25s}
.pf-chip.active{background:var(--grad);border-color:transparent;color:#fff;box-shadow:var(--shadow-sm)}
.pf-chip.active .n{color:#fff;background:rgba(255,255,255,.22)}
.pf-card.hidden{display:none}
.pf-empty{color:var(--muted);font-size:1rem;margin:1rem 0 2.5rem}
.pf-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.pf-card{--accent:var(--brand);--accent-soft:var(--grad-soft);background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .35s,box-shadow .35s}
.pf-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.pf-thumb{position:relative;overflow:hidden;aspect-ratio:4/3;background:var(--accent-soft)}
.pf-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.pf-card:hover .pf-thumb img{transform:scale(1.05)}
.pf-cat{position:absolute;top:12px;left:12px;font-family:var(--ff-mono);font-size:.68rem;background:var(--accent);color:#fff;padding:.3rem .7rem;border-radius:999px;font-weight:500;box-shadow:0 8px 18px -8px var(--accent)}
.pf-body{padding:1.3rem 1.4rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.pf-body h3{font-size:1.12rem}
.pf-body .type{font-size:.8rem;color:var(--muted)}
.pf-link{width:42px;height:42px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;flex:none;transition:.3s;box-shadow:0 10px 22px -10px var(--accent)}
.pf-card:hover .pf-link{transform:scale(1.08)}
.pf-link svg{width:18px;height:18px}
/* CTA spans the whole row so it always reads as a deliberate banner,
   never as a lone stretched card at the end of a filtered grid. */
.pf-cta{grid-column:1 / -1;display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:1.5rem;text-align:left;border:2px dashed var(--line);background:var(--grad-soft);padding:1.7rem 2rem}
.pf-cta .pf-cta-text{display:flex;align-items:center;gap:1.2rem}
.pf-cta .svc-ico{background:var(--grad);color:#fff;flex:none}
.pf-cta h3{font-size:1.2rem;margin-bottom:.15rem}
.pf-cta p{font-size:.92rem;color:var(--muted)}
.pf-cta .btn{flex:none}
@media(max-width:620px){.pf-cta{flex-direction:column;text-align:center}.pf-cta .pf-cta-text{flex-direction:column;text-align:center}}

.ind-cloud{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1rem}
.ind-cloud span{display:inline-flex;align-items:center;gap:.55rem;padding:.75rem 1.25rem;border:1px solid var(--line);border-radius:999px;font-size:.94rem;color:var(--text);background:var(--surface);font-weight:500;transition:.3s}
.ind-cloud span::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--grad)}
.ind-cloud span:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm);color:var(--brand);border-color:var(--cyan)}

.cta-band{background:var(--grad);border-radius:28px;padding:clamp(2.5rem,5vw,4rem);position:relative;overflow:hidden;color:#fff}
.cta-band .blob2{position:absolute;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.18),transparent 70%);right:-60px;top:-80px}
.cta-grid{display:grid;grid-template-columns:1.3fr .7fr;gap:2rem;align-items:center;position:relative;z-index:1}
.cta-band h2{color:#fff;font-size:clamp(1.8rem,3.6vw,2.6rem);margin-bottom:.8rem}
.cta-band p{color:rgba(255,255,255,.9);max-width:46ch}
.cta-band .btn-light{margin-top:0}
.cta-art img{margin-left:auto;max-width:240px}

.vision-card{background:var(--surface);border:1px solid var(--line);border-radius:28px;padding:clamp(2.5rem,5vw,4rem);text-align:center;box-shadow:var(--shadow);position:relative;overflow:hidden}
.vision-card .yrs{font-family:var(--ff-mono);color:var(--brand);letter-spacing:.2em;font-size:.95rem}
.vision-card h2{font-size:clamp(1.9rem,4vw,3rem);margin:1rem auto 1.1rem;max-width:18ch}
.vision-card p{color:var(--muted);max-width:62ch;margin:0 auto 1.8rem}

.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:3rem;align-items:start}
.cinfo-item{display:flex;gap:1rem;align-items:flex-start;padding:1.2rem;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);margin-bottom:1rem;transition:.3s}
.cinfo-item:hover{box-shadow:var(--shadow-sm)}
.cinfo-item .ic{width:46px;height:46px;border-radius:12px;background:var(--grad-soft);color:var(--brand);display:grid;place-items:center;flex:none}
.cinfo-item .ic svg{width:22px;height:22px}
.cinfo-item .k{font-size:.74rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-family:var(--ff-mono)}
.cinfo-item .v{color:var(--ink);font-weight:600;font-size:.98rem}
.cinfo-item a.v:hover{color:var(--brand)}

.form-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:2.2rem;box-shadow:var(--shadow)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field{margin-bottom:1.1rem}
.field label{display:block;font-size:.82rem;color:var(--ink);margin-bottom:.45rem;font-weight:600}
.field input,.field select,.field textarea{width:100%;padding:.85rem 1rem;border-radius:var(--radius-sm);background:var(--bg);border:1.5px solid var(--line);color:var(--ink);font-family:inherit;font-size:.95rem;transition:border-color .25s,box-shadow .25s,background .25s}
.field textarea{resize:vertical;min-height:120px}
.field input::placeholder,.field textarea::placeholder{color:var(--muted-2)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--cyan);background:#fff;box-shadow:0 0 0 4px rgba(17,189,236,.12)}
.field.invalid input,.field.invalid textarea,.field.invalid select{border-color:#e0556b}
.field .err{display:none;color:#d23a52;font-size:.78rem;margin-top:.35rem}
.field.invalid .err{display:block}
.hp{position:absolute;left:-9999px;opacity:0}
.form-note{font-size:.8rem;color:var(--muted-2);margin-top:.8rem}
.form-status{margin-top:1rem;padding:.9rem 1.1rem;border-radius:var(--radius-sm);font-size:.9rem;display:none}
.form-status.show{display:block}
.form-status.ok{background:#e6f7ee;border:1px solid #b6e6c9;color:#0c7a40}
.form-status.bad{background:#fdeaed;border:1px solid #f4c2cb;color:#c43250}
.btn[disabled]{opacity:.6;cursor:not-allowed}

.site-footer{background:#0c2742;color:#b9cde2;padding:4rem 0 2rem}
.site-footer h4{font-family:var(--ff-display);font-size:.95rem;margin-bottom:1.1rem;color:#fff}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.3fr;gap:2.5rem}
.foot-brand img{height:42px;margin-bottom:1.2rem;filter:brightness(0) invert(1)}
.foot-brand p{font-size:.92rem;max-width:32ch;color:#9fb6d0}
.foot-col a,.foot-col p{display:block;color:#9fb6d0;font-size:.9rem;margin-bottom:.65rem;transition:color .25s}
.foot-col a:hover{color:var(--cyan)}
.socials{display:flex;gap:.7rem;margin-top:1.4rem}
.socials a{width:40px;height:40px;border-radius:11px;background:rgba(255,255,255,.08);display:grid;place-items:center;color:#cfe0f1;transition:.3s}
.socials a:hover{background:var(--grad);color:#fff;transform:translateY(-3px)}
.socials svg{width:18px;height:18px}
.foot-bottom{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;align-items:center;margin-top:3rem;padding-top:1.6rem;border-top:1px solid rgba(255,255,255,.1);color:#7e98b5;font-size:.82rem}
.foot-bottom a{color:#7e98b5}
.foot-bottom a:hover{color:var(--cyan)}
.foot-legal{display:flex;gap:1.4rem;flex-wrap:wrap}

[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
[data-reveal].in{opacity:1;transform:none}

@media(max-width:980px){
  .hero-inner,.grid-2,.contact-grid,.cta-grid{grid-template-columns:1fr;gap:2.4rem}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-3,.pf-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .hero-art{order:-1;max-width:460px;margin-inline:auto}
  .cta-art{display:none}
}
@media(max-width:760px){
  .nav-links,.nav-phone{display:none}
  .burger{display:flex}
  .nav-links.mobile{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:#fff;padding:1.5rem 5vw 2rem;gap:1.2rem;box-shadow:var(--shadow);border-top:1px solid var(--line)}
  .nav-links.mobile a{font-size:1.05rem}
  .about-points{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
}
@media(max-width:560px){
  .grid-4,.grid-3,.pf-grid,.steps{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .foot-bottom{flex-direction:column;align-items:flex-start}
}

/* ---------- WhatsApp floating widget -------------------------------- */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:200;display:flex;align-items:center;gap:.6rem;text-decoration:none}
.wa-btn{width:58px;height:58px;border-radius:50%;background:#25d366;color:#fff;display:grid;place-items:center;box-shadow:0 12px 28px -6px rgba(37,211,102,.6);transition:transform .25s,box-shadow .3s;position:relative}
.wa-btn svg{width:34px;height:34px}
.wa-btn::after{content:"";position:absolute;inset:0;border-radius:50%;background:#25d366;opacity:.55;z-index:-1;animation:wa-pulse 2.4s ease-out infinite}
@keyframes wa-pulse{0%{transform:scale(1);opacity:.5}70%{transform:scale(1.7);opacity:0}100%{opacity:0}}
.wa-float:hover .wa-btn{transform:scale(1.08);box-shadow:0 16px 34px -6px rgba(37,211,102,.7)}
.wa-tip{background:#0c2742;color:#fff;font-size:.84rem;font-weight:600;padding:.55rem .9rem;border-radius:10px;white-space:nowrap;box-shadow:var(--shadow-sm);opacity:0;transform:translateX(8px);pointer-events:none;transition:opacity .25s,transform .25s}
.wa-tip::after{content:"";position:absolute;right:-5px;top:50%;transform:translateY(-50%) rotate(45deg);width:10px;height:10px;background:#0c2742;border-radius:1px}
.wa-float:hover .wa-tip{opacity:1;transform:translateX(0)}
@media(prefers-reduced-motion:reduce){.wa-btn::after{animation:none}}
@media(max-width:560px){.wa-float{right:16px;bottom:16px}.wa-tip{display:none}.wa-btn{width:54px;height:54px}.wa-btn svg{width:31px;height:31px}}

/* ===================================================================
   Article / service body typography
   =================================================================== */
.article-body{color:var(--text);font-size:1.05rem;line-height:1.8}
.article-body p{margin:0 0 1.2rem}
.article-body h2{font-family:var(--ff-display);color:var(--ink);font-size:1.5rem;margin:2rem 0 1rem}
.article-body h3{font-family:var(--ff-display);color:var(--ink);font-size:1.2rem;margin:1.6rem 0 .8rem}
.article-body ul,.article-body ol{margin:0 0 1.4rem;padding-left:1.2rem}
.article-body li{margin:.4rem 0}
.article-body a:not(.btn){color:var(--brand);font-weight:600}
.article-body a:not(.btn):hover{text-decoration:underline}
.article-body .lead{font-size:1.2rem;line-height:1.6;margin-bottom:1.6rem}
.article-body strong{color:var(--ink);font-weight:700}
.article-body blockquote{margin:1.8rem 0;padding:1.1rem 1.5rem;border-left:4px solid var(--brand);background:var(--grad-soft);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-family:var(--ff-display);font-size:1.18rem;line-height:1.5;color:var(--ink);font-weight:600}
.article-body blockquote p{margin:0}
.article-body img{max-width:100%;border-radius:var(--radius-sm);margin:1.6rem 0}
.svc-list{list-style:none;padding:0!important;margin:0 0 1.4rem!important;display:grid;gap:.7rem}
.svc-list li{position:relative;padding-left:1.9rem;margin:0;color:var(--text)}
.svc-list li::before{content:"";position:absolute;left:0;top:.45em;width:1.1rem;height:1.1rem;border-radius:50%;background:var(--grad);box-shadow:0 0 0 4px rgba(17,189,236,.12)}

/* ===================================================================
   Admin panel
   =================================================================== */
.admin-body{background:var(--bg-2);font-family:var(--ff-body)}
.btn-sm{padding:.5rem .9rem;font-size:.85rem}
.admin-shell{display:flex;min-height:100vh}
.admin-side{width:248px;background:#0c2742;color:#cfe0f1;display:flex;flex-direction:column;padding:1.4rem 1rem;position:sticky;top:0;height:100vh}
.admin-brand img{height:30px}
.admin-nav{display:flex;flex-direction:column;gap:.25rem;margin-top:2rem;flex:1}
.admin-nav a{display:flex;align-items:center;gap:.7rem;padding:.7rem .85rem;border-radius:10px;color:#aec6df;text-decoration:none;font-weight:600;font-size:.92rem;transition:background .2s,color .2s}
.admin-nav a svg{width:19px;height:19px;flex:none}
.admin-nav a:hover{background:rgba(255,255,255,.06);color:#fff}
.admin-nav a.active{background:var(--grad);color:#fff;box-shadow:0 8px 20px -8px rgba(17,189,236,.6)}
.admin-logout{color:#9fb6cf;text-decoration:none;font-size:.88rem;padding:.7rem .85rem;border-radius:10px;border:1px solid rgba(255,255,255,.12);text-align:center}
.admin-logout:hover{background:rgba(255,255,255,.06);color:#fff}
.admin-main{flex:1;min-width:0;display:flex;flex-direction:column}
.admin-top{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;background:var(--surface);border-bottom:1px solid var(--line)}
.admin-top .role{color:var(--muted);font-weight:500}
.admin-content{padding:2rem;max-width:1100px;width:100%}
.admin-h1{font-family:var(--ff-display);color:var(--ink);font-size:1.7rem;margin:0 0 1.5rem}
.admin-head-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}
.admin-head-row .admin-h1{margin:0}

.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-bottom:2rem}
.stat-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem 1.5rem;box-shadow:var(--shadow-sm)}
.sc-num{font-family:var(--ff-display);font-size:2.2rem;font-weight:800;color:var(--brand);line-height:1}
.sc-lbl{color:var(--muted);font-size:.9rem;margin-top:.4rem}

.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem 1.5rem;box-shadow:var(--shadow-sm);margin-bottom:1.5rem}
.panel h3{font-family:var(--ff-display);color:var(--ink);font-size:1rem;margin:0 0 1rem}
.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.panel-head h2{font-family:var(--ff-display);color:var(--ink);font-size:1.15rem;margin:0}

.admin-table{width:100%;border-collapse:collapse;font-size:.92rem}
.admin-table th{text-align:left;color:var(--muted);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;padding:.6rem .6rem;border-bottom:1px solid var(--line)}
.admin-table td{padding:.85rem .6rem;border-bottom:1px solid var(--line-soft);vertical-align:middle}
.admin-table tr:last-child td{border-bottom:none}
.admin-table a{color:var(--ink);text-decoration:none;font-weight:600}
.admin-table a:hover{color:var(--brand)}
.admin-table .t-slug{font-family:var(--ff-mono);font-size:.74rem;color:var(--muted-2);font-weight:400;margin-top:.15rem}
.admin-table .muted,.muted{color:var(--muted)}
.badge{display:inline-block;padding:.25rem .7rem;border-radius:999px;font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em}
.badge.published{background:#dcfce7;color:#166534}
.badge.draft{background:#fef3c7;color:#92400e}
.actions{text-align:right;white-space:nowrap}
.act{display:inline-block;font-size:.82rem;font-weight:600;text-decoration:none;padding:.35rem .6rem;border-radius:8px;margin-left:.2rem;border:1px solid var(--line);background:#fff;color:var(--text);cursor:pointer}
.act:hover{border-color:var(--brand);color:var(--brand)}
.act.go{color:#166534;border-color:#bbf7d0}.act.go:hover{background:#dcfce7}
.act.warn{color:#92400e;border-color:#fde68a}.act.warn:hover{background:#fef3c7}
.act.del{color:#b91c1c;border-color:#fecaca}.act.del:hover{background:#fee2e2}

.alert{padding:.85rem 1.1rem;border-radius:12px;margin-bottom:1.2rem;font-size:.92rem;font-weight:500}
.alert.ok{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}
.alert.bad{background:#fee2e2;color:#b91c1c;border:1px solid #fecaca}

.form-2col{display:grid;grid-template-columns:1fr 320px;gap:1.5rem;align-items:start}
.form-aside .panel{margin-bottom:1.2rem}
.field .hint{color:var(--muted-2);font-weight:400;font-size:.8rem}
textarea.mono{font-family:var(--ff-mono);font-size:.88rem;line-height:1.6}
.inline-edit{display:contents}
.inline-edit input{width:100%}

/* Login */
.login-body{display:grid;place-items:center;min-height:100vh;background:radial-gradient(1200px 500px at 50% -10%,#e9f2fb,transparent),var(--bg)}
.login-wrap{width:100%;max-width:420px;padding:1.5rem}
.login-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:2.5rem 2rem;text-align:center}
.login-logo{height:38px;margin-bottom:1.4rem}
.login-card h1{font-family:var(--ff-display);color:var(--ink);font-size:1.5rem;margin:0 0 .3rem}
.login-card .sub{color:var(--muted);margin:0 0 1.6rem;font-size:.92rem}
.login-card form{text-align:left}
.login-back{display:inline-block;margin-top:1.2rem;color:var(--muted);text-decoration:none;font-size:.88rem}
.login-back:hover{color:var(--brand)}

@media(max-width:900px){
  .form-2col{grid-template-columns:1fr}
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  .admin-side{width:72px;padding:1.2rem .6rem}
  .admin-brand img{height:24px}
  .admin-nav a span,.admin-nav a{font-size:0}
  .admin-nav a svg{width:22px;height:22px}
  .admin-logout{font-size:0;padding:.6rem}
}

/* ===================================================================
   Testimonials (home page)
   =================================================================== */
.tm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:1rem}
.tm-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1rem;margin:0;position:relative;overflow:hidden}
.tm-card::before{content:"\201C";position:absolute;top:-1.2rem;right:1rem;font-family:var(--ff-display);font-size:6rem;color:var(--cyan);opacity:.12;line-height:1}
.tm-stars{color:#f5a623;font-size:1rem;letter-spacing:.1em}
.tm-stars .off{color:#d8e3ef}
.tm-card blockquote{margin:0;color:var(--text);font-size:1.02rem;line-height:1.7;flex:1}
.tm-person{display:flex;align-items:center;gap:.8rem;margin-top:.4rem}
.tm-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;flex:none}
.tm-avatar.ph{display:grid;place-items:center;background:var(--grad);color:#fff;font-family:var(--ff-display);font-weight:700;font-size:1.1rem}
.tm-name{display:block;font-family:var(--ff-display);font-weight:700;color:var(--ink);font-size:.98rem}
.tm-role{display:block;color:var(--muted);font-size:.85rem}
@media(max-width:980px){.tm-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.tm-grid{grid-template-columns:1fr}}

/* ===================================================================
   Admin — additions for enquiries, testimonials, uploads, editor
   =================================================================== */
.nav-badge{margin-left:auto;background:#ef4444;color:#fff;font-size:.7rem;font-weight:700;min-width:20px;height:20px;border-radius:999px;display:inline-grid;place-items:center;padding:0 .35rem}
.admin-nav a{position:relative}

.row-unread td{background:#f3f9ff}
.row-unread .t-title{color:var(--brand)}
.dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#ef4444;margin-right:.45rem;vertical-align:middle}
.enq-msg{color:var(--text);font-size:1.02rem;line-height:1.8;white-space:pre-wrap}
.enq-dl{display:grid;grid-template-columns:auto 1fr;gap:.45rem 1rem;margin:0;font-size:.92rem}
.enq-dl dt{color:var(--muted);font-weight:600}
.enq-dl dd{margin:0;color:var(--ink);word-break:break-word}
.enq-dl a{color:var(--brand)}

.person{display:flex;align-items:center;gap:.7rem}
.avatar-sm{width:38px;height:38px;border-radius:50%;object-fit:cover;flex:none}
.avatar-sm.ph{display:grid;place-items:center;background:var(--grad);color:#fff;font-weight:700;font-size:.95rem}
.quote-cell{max-width:360px}

.img-current{display:flex;flex-direction:column;gap:.6rem;margin-bottom:1rem}
.img-current img{width:100%;max-height:160px;object-fit:cover;border-radius:12px;border:1px solid var(--line)}
.img-current .rm{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--muted)}
input[type=file]{font-size:.88rem;color:var(--text)}
input[type=file]::file-selector-button{margin-right:.7rem;padding:.5rem .9rem;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--text);font-weight:600;cursor:pointer;font-family:inherit}
input[type=file]::file-selector-button:hover{border-color:var(--brand);color:var(--brand)}
.check-row{display:flex;align-items:center;gap:.6rem;font-weight:600;color:var(--ink);cursor:pointer}

/* Quill editor */
#editor-wrap{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff}
#editor{min-height:320px;font-family:var(--ff-body);font-size:1rem}
.ql-toolbar.ql-snow{border:none;border-bottom:1px solid var(--line);background:var(--bg)}
.ql-container.ql-snow{border:none}
.ql-editor{min-height:320px;line-height:1.7}
.ql-editor h2{font-family:var(--ff-display);font-size:1.4rem}
.ql-editor h3{font-family:var(--ff-display);font-size:1.15rem}
