/* =============================================================
   Ultra Renovations Inc — main.css v2
   © 2025 Ultra Renovations Inc. All rights reserved.
   Light / Dark mode with smooth CSS custom property transitions.
   ============================================================= */

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}

/* =============================================================
   DARK MODE TOKENS  (default)
   ============================================================= */
:root{
  --gold:#C8A44A; --gold-lt:#E2C47A;
  --gold-dim:rgba(200,164,74,.12); --gold-bd:rgba(200,164,74,.22);

  --bg:#0d0d0d; --bg-2:#131313; --bg-3:#1a1a1a; --bg-4:#222;
  --text:#F5F3EF; --text-2:rgba(245,243,239,.62); --text-3:rgba(245,243,239,.35);
  --muted:#7a7a7a; --border:rgba(200,164,74,.14); --border-2:rgba(200,164,74,.24);

  --nav-bg:rgba(13,13,13,.97); --nav-mob-bg:rgba(13,13,13,.99);
  --card-bg:#1a1a1a; --card-border:rgba(200,164,74,.2);
  --input-bg:rgba(0,0,0,.35); --input-bd:rgba(200,164,74,.16);
  --hero-glow:rgba(200,164,74,.07);

  /* Toggle pill */
  --tt-track:rgba(200,164,74,.15); --tt-thumb:#0d0d0d;

  --r:3px; --max:1280px;
}

/* =============================================================
   LIGHT MODE TOKENS
   ============================================================= */
html.ur-light{
  --gold:#9A6E10; --gold-lt:#B8891E;
  --gold-dim:rgba(154,110,16,.09); --gold-bd:rgba(154,110,16,.28);

  --bg:#F7F4EF; --bg-2:#EDE9E2; --bg-3:#E3DECE; --bg-4:#D6D0C4;
  --text:#1A1612; --text-2:rgba(26,22,18,.62); --text-3:rgba(26,22,18,.35);
  --muted:#8a7f6e; --border:rgba(154,110,16,.16); --border-2:rgba(154,110,16,.3);

  --nav-bg:rgba(247,244,239,.97); --nav-mob-bg:rgba(247,244,239,.99);
  --card-bg:#ffffff; --card-border:rgba(154,110,16,.2);
  --input-bg:rgba(255,255,255,.9); --input-bd:rgba(154,110,16,.22);
  --hero-glow:rgba(200,164,74,.12);

  --tt-track:rgba(154,110,16,.18); --tt-thumb:#ffffff;
}

/* =============================================================
   GLOBAL MODE TRANSITION
   ============================================================= */
body.ur-site,
body.ur-site section,
body.ur-site header,
body.ur-site footer,
body.ur-site nav,
body.ur-site div,
body.ur-site article,
body.ur-site input,
body.ur-site select,
body.ur-site textarea,
body.ur-site button:not(.filt):not(.btn):not(.nav-est){
  transition:
    background-color .38s ease,
    background .38s ease,
    border-color .38s ease,
    color .38s ease,
    box-shadow .38s ease;
}

/* =============================================================
   BASE
   ============================================================= */
body.ur-site{
  font-family:'DM Sans',sans-serif;
  background:var(--bg); color:var(--text);
  overflow-x:hidden; line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
body.ur-site img{max-width:100%;height:auto;display:block}
body.ur-site a{text-decoration:none;color:inherit}
body.ur-site ul,body.ur-site ol{list-style:none}
body.ur-site h1,body.ur-site h2,body.ur-site h3,body.ur-site h4{font-family:'Playfair Display',serif;line-height:1.1;font-weight:700}
body.ur-site button{cursor:pointer;font-family:inherit;border:none;background:none}
body.ur-site input,body.ur-site select,body.ur-site textarea{font-family:inherit}
body.ur-site address,body.ur-site blockquote,body.ur-site cite{font-style:normal;display:block}
body.ur-site abbr{text-decoration:none;border:none}

/* =============================================================
   UTILITIES
   ============================================================= */
.tag{display:block;font-size:.68rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:.8rem}
.h2{font-size:clamp(1.75rem,3.2vw,2.7rem);font-weight:700;line-height:1.1;margin-bottom:1rem;color:var(--text)}
.lead{font-size:.98rem;color:var(--text-2);line-height:1.88;font-weight:300;max-width:520px}
.gold-bar{width:44px;height:2px;background:var(--gold);margin:1rem 0 1.8rem;display:block}
.gold-link{color:var(--gold);font-weight:600}.gold-link:hover{color:var(--gold-lt)}
.section-inner{max-width:var(--max);margin:0 auto}
.section-top{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1.5rem;margin-bottom:3.5rem}
.section-top .lead{margin-bottom:0;max-width:400px}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .65s ease,transform .65s ease}
.reveal.in{opacity:1;transform:none}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:'DM Sans',sans-serif;font-weight:700;font-size:.84rem;letter-spacing:.08em;text-transform:uppercase;padding:.9rem 2rem;border-radius:var(--r);transition:all .2s;white-space:nowrap;line-height:1;cursor:pointer;border:none}
.btn-g{background:var(--gold);color:#0d0d0d}.btn-g:hover{background:var(--gold-lt);transform:translateY(-2px);color:#0d0d0d}
.btn-o{background:transparent;border:1.5px solid var(--gold-bd);color:var(--gold)}.btn-o:hover{border-color:var(--gold);background:var(--gold-dim)}
.btn-w{display:flex;justify-content:center;width:100%}

/* =============================================================
   THEME TOGGLE
   ============================================================= */
.theme-tog{
  display:flex;align-items:center;justify-content:center;
  background:none;border:none;cursor:pointer;
  padding:3px;flex-shrink:0;border-radius:100px;
  /* Gold ring so it's always findable */
  outline:1.5px solid var(--gold-bd);
  transition:outline-color .3s;
}
.theme-tog:hover{outline-color:var(--gold)}
.theme-tog:focus-visible{outline:2px solid var(--gold);outline-offset:2px}

/* Pill track */
.tt-track{
  width:48px;height:26px;
  background:var(--tt-track);
  border:1.5px solid var(--gold-bd);
  border-radius:100px;
  position:relative;display:block;
  transition:background .38s,border-color .38s;
  min-width:48px;
}
/* Sliding thumb */
.tt-thumb{
  position:absolute;top:2px;left:2px;
  width:20px;height:20px;border-radius:50%;
  background:var(--gold);
  display:flex;align-items:center;justify-content:center;
  transition:transform .38s cubic-bezier(.34,1.56,.64,1),background .38s;
  box-shadow:0 2px 8px rgba(0,0,0,.4);
}
html.ur-light .tt-thumb{transform:translateX(22px)}

/* Icons inside thumb */
.ico-moon,.ico-sun{
  width:11px;height:11px;position:absolute;
  transition:opacity .22s,transform .22s;
}
.ico-moon{opacity:1;color:#0d0d0d;transform:scale(1)}
.ico-sun {opacity:0;color:#0d0d0d;transform:scale(.4) rotate(-30deg)}
html.ur-light .ico-moon{opacity:0;transform:scale(.4) rotate(30deg)}
html.ur-light .ico-sun {opacity:1;transform:scale(1) rotate(0deg)}

/* =============================================================
   NAVIGATION
   ============================================================= */
#ur-header{
  position:fixed;top:0;left:0;right:0;z-index:9999;
  background:var(--nav-bg);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  transition:box-shadow .3s,background .38s,border-color .38s;
}
.nav-wrap{max-width:var(--max);margin:0 auto;padding:0 5vw;height:68px;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.nav-logo{font-family:'Playfair Display',serif;font-size:1.28rem;font-weight:900;color:var(--text);flex-shrink:0;line-height:1}
.nav-logo span{color:var(--gold)}
.nav-menu{display:flex;align-items:center;gap:.1rem}
.nav-menu a{font-size:.75rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);padding:.48rem .7rem;border-radius:var(--r);transition:color .2s,background .2s;white-space:nowrap}
.nav-menu a:hover{color:var(--text);background:rgba(128,128,128,.08)}
.nav-ph{color:var(--gold)!important;font-weight:700!important}
.nav-ph:hover{color:var(--gold-lt)!important;background:var(--gold-dim)!important}
.nav-est{background:var(--gold)!important;color:#0d0d0d!important;font-weight:700!important;padding:.5rem 1.1rem!important;border-radius:var(--r)!important;margin-left:.4rem}
.nav-est:hover{background:var(--gold-lt)!important;color:#0d0d0d!important}

.nav-controls{display:flex;align-items:center;gap:.6rem;flex-shrink:0}
.nav-tog{display:none;flex-direction:column;justify-content:center;gap:5px;padding:5px;width:34px;height:34px;flex-shrink:0}
.nav-tog span{display:block;height:2px;border-radius:2px;background:var(--text);transition:all .3s}
.nav-tog.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-tog.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-tog.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.nav-mob{display:none;position:fixed;top:68px;left:0;right:0;background:var(--nav-mob-bg);border-bottom:1px solid var(--border);padding:1.25rem 5vw 1.8rem;z-index:9998;transition:background .38s}
.nav-mob.open{display:block}
.nav-mob a{display:block;font-size:.92rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);padding:.8rem 0;border-bottom:1px solid rgba(128,128,128,.1);transition:color .2s}
.nav-mob a:hover{color:var(--gold)}
.nav-mob .mcta{margin-top:1rem;background:var(--gold);color:#0d0d0d!important;text-align:center;padding:.95rem;border-radius:var(--r);font-weight:700;font-size:.88rem;display:block;border-bottom:none!important}
.nav-mob .mcta:hover{background:var(--gold-lt)!important}

.admin-bar #ur-header{top:32px}
.admin-bar .nav-mob{top:calc(68px + 32px)}
@media screen and (max-width:782px){
  .admin-bar #ur-header{top:46px}
  .admin-bar .nav-mob{top:calc(68px + 46px)}
}

/* =============================================================
   HERO
   ============================================================= */
#hero{min-height:100vh;display:flex;align-items:center;padding:calc(68px + 5rem) 5vw 5rem;background:var(--bg);position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 75% 55% at 65% 50%,var(--hero-glow) 0%,transparent 70%),
  repeating-linear-gradient(45deg,transparent,transparent 40px,rgba(200,164,74,.015) 40px,rgba(200,164,74,.015) 41px)}
.hero-wrap{display:grid;grid-template-columns:1fr 400px;gap:4rem;align-items:center;max-width:var(--max);margin:0 auto;width:100%;position:relative;z-index:1}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.55rem;background:var(--gold-dim);border:1px solid var(--gold-bd);color:var(--gold);font-size:.7rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;padding:.38rem .95rem;border-radius:2px;margin-bottom:1.8rem;animation:fadeUp .7s ease both}
.hero-h1{font-size:clamp(2.5rem,5.2vw,4.8rem);font-weight:900;letter-spacing:-.025em;line-height:1.05;margin-bottom:1.4rem;color:var(--text);animation:fadeUp .7s .1s ease both}
.hero-h1 em{font-style:normal;color:var(--gold)}
.hero-p{font-size:1.02rem;font-weight:300;color:var(--text-2);line-height:1.82;max-width:500px;margin-bottom:2.4rem;animation:fadeUp .7s .2s ease both}
.hero-btns{display:flex;gap:.85rem;flex-wrap:wrap;animation:fadeUp .7s .3s ease both;margin-bottom:2.8rem}
.hero-stats{display:flex;align-items:center;gap:2.2rem;flex-wrap:wrap;animation:fadeUp .7s .4s ease both;padding-top:1.5rem;border-top:1px solid var(--border)}
.hstat .n{font-family:'Playfair Display',serif;font-size:1.55rem;font-weight:700;color:var(--gold);line-height:1;display:block}
.hstat .l{font-size:.68rem;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--muted);margin-top:.2rem;display:block}

.hero-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:5px;padding:2.4rem;animation:fadeUp .7s .35s ease both;position:relative;overflow:hidden}
.hero-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-lt))}
.hc-title{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:700;margin-bottom:.35rem;color:var(--text)}
.hc-sub{font-size:.82rem;color:var(--muted);margin-bottom:1.6rem;line-height:1.5}
.hc-list{display:flex;flex-direction:column;gap:.6rem;margin-bottom:1.8rem;padding:0}
.hc-item{display:flex;align-items:center;gap:.7rem;font-size:.88rem;color:var(--text-2);padding:.55rem .75rem;background:var(--gold-dim);border-radius:var(--r);border:1px solid var(--gold-bd)}
.hc-ico{color:var(--gold);font-weight:700;flex-shrink:0}
.hc-rating{display:flex;align-items:center;gap:.8rem;padding:.9rem 1rem;background:var(--gold-dim);border-radius:var(--r);margin-bottom:1.4rem;border:1px solid var(--gold-bd)}
.hc-stars{color:var(--gold);font-size:.95rem;display:block}
.hc-rtxt{font-size:.8rem;color:var(--muted);line-height:1.45}
.hc-rtxt strong{color:var(--text);display:block;font-weight:600}

/* =============================================================
   SERVICES
   ============================================================= */
#services{padding:7rem 5vw;background:var(--bg-2)}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--border)}
.sc{background:var(--bg-3);padding:2.4rem 2.2rem;position:relative;overflow:hidden;transition:background .25s}
.sc::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--gold);transition:width .38s}
.sc:hover{background:var(--bg-4)}.sc:hover::after{width:100%}
.sc-ico{width:50px;height:50px;background:var(--gold-dim);border:1px solid var(--gold-bd);border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-size:1.35rem;margin-bottom:1.3rem;color:var(--gold);font-weight:700;font-family:'Playfair Display',serif}
.sc h3{font-size:1.08rem;font-weight:700;margin-bottom:.65rem;color:var(--text)}
.sc p{font-size:.87rem;color:var(--muted);line-height:1.78}

/* =============================================================
   WHY CHOOSE US
   ============================================================= */
#why{padding:7rem 5vw;background:var(--bg)}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center}
.why-left{position:relative;padding-bottom:2.5rem}
.why-qcard{background:var(--card-bg);border:1px solid var(--card-border);border-radius:5px;padding:3rem;position:relative}
.why-qcard::before{content:'\201C';position:absolute;top:.8rem;left:1.8rem;font-family:'Playfair Display',serif;font-size:7rem;line-height:1;color:var(--gold);opacity:.12;pointer-events:none}
.wq-stars{color:var(--gold);font-size:1rem;margin-bottom:1.1rem}
.wq-text{font-family:'Playfair Display',serif;font-size:1.02rem;font-style:italic;line-height:1.82;color:var(--text);margin-bottom:1.1rem;display:block}
.wq-author{font-size:.76rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);display:block}
.why-badge{position:absolute;bottom:0;right:-1rem;background:var(--gold);color:#0d0d0d;padding:1.1rem 1.4rem;border-radius:4px;text-align:center;box-shadow:0 10px 40px rgba(200,164,74,.25)}
.wb-n{font-family:'Playfair Display',serif;font-size:1.9rem;font-weight:900;line-height:1;display:block}
.wb-l{font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-top:.2rem;display:block}
.why-pts{display:flex;flex-direction:column;gap:1.4rem;margin-bottom:2.5rem;padding:0}
.wp{display:flex;gap:1rem;align-items:flex-start}
.wp-ic{width:40px;height:40px;border-radius:50%;background:var(--gold-dim);border:1px solid var(--gold-bd);display:flex;align-items:center;justify-content:center;font-size:.95rem;flex-shrink:0;margin-top:.1rem;color:var(--gold);font-weight:700}
.wp-bd h4{font-size:.93rem;font-weight:700;margin-bottom:.22rem;color:var(--text)}
.wp-bd p{font-size:.85rem;color:var(--muted);line-height:1.68}

/* =============================================================
   PROCESS
   ============================================================= */
#process{padding:7rem 5vw;background:var(--bg-2)}
.proc-hd{text-align:center;max-width:560px;margin:0 auto 4rem}
.proc-hd .gold-bar{margin:1rem auto 1.8rem}
.proc-hd .lead{margin:0 auto}
.proc-row{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;position:relative}
.proc-row::before{content:'';position:absolute;top:2.2rem;left:14%;right:14%;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.28}
.ps{text-align:center}
.ps-n{width:4.4rem;height:4.4rem;border-radius:50%;border:2px solid var(--gold);background:var(--card-bg);display:flex;align-items:center;justify-content:center;margin:0 auto 1.3rem;font-family:'Playfair Display',serif;font-size:1.25rem;font-weight:700;color:var(--gold);position:relative;z-index:1}
.ps h3{font-size:.98rem;font-weight:700;margin-bottom:.55rem;color:var(--text)}
.ps p{font-size:.84rem;color:var(--muted);line-height:1.72}

/* =============================================================
   GALLERY
   ============================================================= */
#gallery{padding:7rem 5vw;background:var(--bg)}
.gal-top{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1.5rem;margin-bottom:2rem}
.gal-filters{display:flex;gap:.45rem;flex-wrap:wrap;margin-bottom:2.5rem}
.filt{background:none;border:1px solid var(--border-2);color:var(--muted);font-family:'DM Sans',sans-serif;font-size:.75rem;font-weight:600;letter-spacing:.09em;text-transform:uppercase;padding:.42rem 1rem;border-radius:2px;cursor:pointer;transition:all .2s}
.filt.on,.filt:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-dim)}
.gal-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:230px;gap:.8rem}
.gi{position:relative;overflow:hidden;border-radius:var(--r);background:var(--bg-3);border:1px solid var(--border)}
.gi.s2{grid-row:span 2}
.gi-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.gi:hover .gi-img{transform:scale(1.07)}
.gi::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.5) 0%,transparent 55%);pointer-events:none}
.gi-ov{position:absolute;inset:0;z-index:2;background:linear-gradient(to top,rgba(0,0,0,.88) 0%,rgba(0,0,0,.2) 60%,transparent 100%);opacity:0;transition:opacity .32s;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-end;padding:1.4rem}
.gi:hover .gi-ov{opacity:1}
.gi-ov h4{font-size:.95rem;font-weight:700;color:#fff;margin-bottom:.2rem}
.gi-ov span{font-size:.72rem;color:var(--gold-lt);letter-spacing:.07em;text-transform:uppercase;font-weight:600}

/* =============================================================
   REVIEWS
   ============================================================= */
#reviews{padding:7rem 5vw;background:var(--bg-2)}
.rev-top{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1.5rem;margin-bottom:3rem}
.g-badge{display:flex;align-items:center;gap:1rem;background:var(--card-bg);border:1px solid var(--card-border);padding:.9rem 1.4rem;border-radius:var(--r)}
.g-num{font-family:'Playfair Display',serif;font-size:2rem;font-weight:700;color:var(--gold);line-height:1}
.g-meta{font-size:.78rem;color:var(--muted);line-height:1.6;display:flex;flex-direction:column;gap:.1rem}
.gst{color:var(--gold);font-size:.88rem}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.rc{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--r);padding:1.75rem;transition:border-color .25s,transform .25s;display:flex;flex-direction:column}
.rc:hover{border-color:var(--gold-bd);transform:translateY(-3px);box-shadow:0 8px 30px rgba(0,0,0,.06)}
.rc-s{color:var(--gold);margin-bottom:.75rem;font-size:.88rem;display:block}
.rc-t{font-size:.9rem;line-height:1.82;color:var(--text-2);font-style:italic;margin-bottom:1.2rem;flex-grow:1;display:block}
.rc-a{font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);display:block}
.rc-src{font-size:.7rem;color:var(--muted);margin-top:.15rem;display:block}

/* =============================================================
   SERVICE AREAS
   ============================================================= */
#areas{padding:7rem 5vw;background:var(--bg)}
.areas-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}
.a-pills{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.8rem}
.ap{display:inline-block;border:1px solid var(--border-2);color:var(--text-2);font-size:.78rem;font-weight:500;padding:.34rem .82rem;border-radius:2px;transition:all .2s}
.ap:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-dim)}
.a-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:5px;padding:2.8rem}
.a-card h3{font-size:1.45rem;font-weight:700;margin-bottom:.75rem;line-height:1.2;color:var(--text)}
.a-card>p{font-size:.9rem;color:var(--muted);line-height:1.78;margin-bottom:1.8rem}
.ilist{display:flex;flex-direction:column;gap:.85rem;padding:0}
.ir{display:flex;align-items:flex-start;gap:.85rem}
.ir-ic{font-size:1rem;flex-shrink:0;margin-top:.15rem;width:1.2rem;text-align:center}
.ir-bd strong{display:block;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:.1rem}
.ir-bd span,.ir-bd a{font-size:.88rem;color:var(--text-2);display:block;line-height:1.5}
.ir-bd a:hover{color:var(--gold)}

/* =============================================================
   CONTACT
   ============================================================= */
#contact{padding:7rem 5vw;background:var(--bg-2)}
.con-grid{display:grid;grid-template-columns:1fr 1.35fr;gap:5rem;align-items:start}
.map-box{border-radius:var(--r);overflow:hidden;border:1px solid var(--border);margin-top:2rem}
.map-box iframe{width:100%;height:210px;border:none;display:block;filter:grayscale(80%) invert(88%) hue-rotate(170deg)}
html.ur-light .map-box iframe{filter:grayscale(20%)}
.con-form{background:var(--card-bg);border:1px solid var(--border);border-radius:5px;padding:3rem}
.con-form h3{font-size:1.38rem;font-weight:700;margin-bottom:.35rem;color:var(--text)}
.cf-sub{font-size:.86rem;color:var(--muted);margin-bottom:1.9rem;display:block}
.f2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.fg{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.95rem}
.fg label{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold)}
.fg abbr{color:var(--gold)}
.fg input,.fg select,.fg textarea{background:var(--input-bg);border:1px solid var(--input-bd);color:var(--text);font-size:.9rem;padding:.78rem .95rem;border-radius:var(--r);outline:none;transition:border-color .2s;width:100%}
.fg input::placeholder,.fg textarea::placeholder{color:var(--text-3)}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--gold)}
.fg select{cursor:pointer}
.fg select option{background:var(--bg-3);color:var(--text)}
.fg textarea{resize:vertical;min-height:120px}
.fnote{font-size:.74rem;color:var(--muted);margin-bottom:1.4rem;display:block}
.f-ok{display:none;background:var(--gold-dim);border:1px solid var(--gold);border-radius:var(--r);padding:.9rem 1.2rem;margin-top:.9rem;font-size:.87rem;color:var(--gold);text-align:center}

/* =============================================================
   FAQ
   ============================================================= */
#faq{padding:7rem 5vw;background:var(--bg)}
.faq-grid{display:grid;grid-template-columns:1fr 1.7fr;gap:5rem;align-items:start}
.faq-acc{border-top:1px solid var(--border)}
.fi{border-bottom:1px solid var(--border)}
.fq{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 0;cursor:pointer;gap:1rem;user-select:none;-webkit-tap-highlight-color:transparent}
.fq span{font-size:.93rem;font-weight:500;color:var(--text);line-height:1.45}
.fi-ico{color:var(--gold);font-size:1.4rem;font-weight:300;flex-shrink:0;transition:transform .3s;line-height:1}
.fi.on .fi-ico{transform:rotate(45deg)}
.fa{max-height:0;overflow:hidden;transition:max-height .4s ease}
.fa p{font-size:.88rem;color:var(--muted);line-height:1.82;padding-bottom:1.2rem}
.fi.on .fa{max-height:280px}

/* =============================================================
   CTA STRIP
   ============================================================= */
#cta-strip{padding:5.5rem 5vw;text-align:center;background:var(--bg-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);position:relative;overflow:hidden}
#cta-strip::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 60% 80% at 50% 50%,var(--gold-dim),transparent 70%)}
.cta-inner{max-width:660px;margin:0 auto;position:relative;z-index:1}
.cta-inner h2{font-size:clamp(1.65rem,3.2vw,2.5rem);font-weight:700;margin-bottom:1rem;color:var(--text)}
.cta-inner p{font-size:.97rem;color:var(--text-2);margin-bottom:2.4rem;line-height:1.78}
.cta-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* =============================================================
   FOOTER
   ============================================================= */
#ur-footer{background:var(--bg-2);border-top:1px solid var(--border);padding:4.5rem 5vw 2.5rem}
.ft-g{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3.5rem}
.ft-logo{font-family:'Playfair Display',serif;font-size:1.26rem;font-weight:900;color:var(--text);display:block;margin-bottom:.95rem;line-height:1}
.ft-logo span{color:var(--gold)}
.ft-tag{font-size:.86rem;color:var(--muted);line-height:1.75;max-width:240px}
.ft-h{font-size:.68rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:1.15rem;display:block}
.ft-lk{display:flex;flex-direction:column;gap:.6rem}
.ft-lk a{font-size:.86rem;color:var(--muted);transition:color .2s}
.ft-lk a:hover{color:var(--text)}
.ft-cl{display:flex;flex-direction:column;gap:.6rem}
.ft-cl span{font-size:.86rem;color:var(--muted);display:flex;align-items:flex-start;gap:.5rem;line-height:1.55}
.ft-cl a{color:var(--muted)}.ft-cl a:hover{color:var(--gold)}
.ft-bot{border-top:1px solid var(--border);padding-top:1.9rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem}
.ft-copy{font-size:.75rem;color:var(--muted)}
.ft-leg{display:flex;gap:1.4rem}
.ft-leg a{font-size:.75rem;color:var(--muted);transition:color .2s}
.ft-leg a:hover{color:var(--gold)}

/* =============================================================
   KEYFRAMES
   ============================================================= */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

/* =============================================================
   RESPONSIVE
   ============================================================= */
@media(max-width:1100px){
  .hero-wrap{grid-template-columns:1fr;gap:2.5rem}
  .hero-card{display:none}
  .ft-g{grid-template-columns:1fr 1fr;gap:2.5rem}
}
@media(max-width:1024px){
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:1fr;gap:3.5rem}
  .why-badge{right:0;bottom:-1rem}
  .proc-row{grid-template-columns:repeat(2,1fr)}
  .proc-row::before{display:none}
  .gal-grid{grid-template-columns:repeat(2,1fr)}
  .rev-grid{grid-template-columns:repeat(2,1fr)}
  .areas-grid{grid-template-columns:1fr;gap:3rem}
  .con-grid{grid-template-columns:1fr;gap:3rem}
  .faq-grid{grid-template-columns:1fr;gap:2.5rem}
  .section-top{flex-direction:column;align-items:flex-start}
}
@media(max-width:768px){
  .nav-menu{display:none}
  .nav-tog{display:flex}
  /* theme-tog stays visible — it's in .nav-controls which is always shown */
  .svc-grid{grid-template-columns:1fr}
  .rev-grid{grid-template-columns:1fr}
  .gal-top,.rev-top{flex-direction:column;align-items:flex-start}
}
@media(max-width:540px){
  .hero-btns,.cta-btns{flex-direction:column;align-items:flex-start}
  .hero-stats{gap:1.4rem}
  .gal-grid{grid-template-columns:1fr}
  .gi.s2{grid-row:span 1}
  .f2{grid-template-columns:1fr}
  .ft-g{grid-template-columns:1fr}
  .ft-bot{flex-direction:column;text-align:center}
  .ft-leg{justify-content:center}
  .cta-btns{align-items:center}
}

/* =============================================================
   SVG ICON SIZING — ensures all inline SVGs render correctly
   ============================================================= */
.sc-ico svg {
  width: 26px; height: 26px;
  stroke: var(--gold); color: var(--gold);
  display: block;
}
.ir-ic svg {
  width: 16px; height: 16px; flex-shrink: 0;
  stroke: var(--gold); color: var(--gold);
  display: block; margin-top: 2px;
}
.hc-ico svg {
  stroke: var(--gold); color: var(--gold);
}
.ft-cl svg {
  width: 14px; height: 14px; flex-shrink: 0;
  stroke: var(--gold); color: var(--gold);
  margin-top: 3px;
}
/* Star SVG filled gold */
.ir-ic svg[fill="currentColor"],
.ft-cl svg[fill="currentColor"] { fill: var(--gold); stroke: none; }

/* Why-points icon */
.wp-ic svg {
  width: 18px; height: 18px;
  stroke: var(--gold); color: var(--gold);
}
