/* James Wand — Secret Agent Magic Show — shared styles */
:root{
  --navy:#0d1b2e;
  --navy-2:#13263d;
  --ink:#1d2530;
  --muted:#5c6675;
  --line:#e7e9ee;
  --gold:#e7b53b;
  --gold-dark:#c9971f;
  --red:#c0392b;
  --red-dark:#9e2b20;
  --bg:#ffffff;
  --tint:#f6f8fb;
  --radius:14px;
  --shadow:0 8px 26px rgba(13,27,46,.10);
  --wrap:1140px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:"Segoe UI",system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:var(--red);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 22px}
.narrow{max-width:800px;margin-inline:auto}
.center{text-align:center}
h1,h2,h3,h4{line-height:1.18;color:var(--navy);margin:0 0 .5em;font-weight:800}
h1{font-size:clamp(2rem,4.2vw,3.1rem)}
h2{font-size:clamp(1.5rem,3vw,2.2rem)}
h3{font-size:1.2rem}
p{margin:0 0 1rem}
.eyebrow{text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;font-weight:800;color:var(--gold-dark);margin:0 0 .5em}
.lead{font-size:1.13rem;color:var(--muted)}
.small{font-size:.9rem;color:var(--muted)}
.skip{position:absolute;left:-999px}
.skip:focus{left:8px;top:8px;background:#fff;padding:.5rem 1rem;z-index:200;border-radius:8px}

/* Buttons */
.btn{display:inline-block;background:var(--red);color:#fff;font-weight:700;padding:.7rem 1.4rem;border-radius:999px;border:2px solid var(--red);transition:.15s ease;cursor:pointer;font-size:1rem;white-space:nowrap}
.btn:hover{background:var(--red-dark);border-color:var(--red-dark);text-decoration:none;transform:translateY(-1px)}
.btn.lg{padding:.9rem 1.8rem;font-size:1.05rem}
.btn.gold{background:var(--gold);border-color:var(--gold);color:var(--navy)}
.btn.gold:hover{background:var(--gold-dark);border-color:var(--gold-dark);color:var(--navy)}
.btn.ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn.ghost:hover{background:rgba(255,255,255,.12);border-color:#fff}

/* Header / nav */
.site-header{position:sticky;top:0;z-index:60;background:var(--navy);border-bottom:2px solid var(--gold)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.5rem 22px;max-width:var(--wrap);margin:0 auto}
.logo{display:flex;align-items:center;gap:.6rem;color:#fff}
.logo:hover{text-decoration:none}
.logo .mark{display:grid;place-items:center;width:42px;height:42px;border-radius:9px;background:var(--gold);color:var(--navy);font-weight:900;font-size:1.05rem;letter-spacing:.02em;box-shadow:inset 0 0 0 2px rgba(13,27,46,.15)}
.logo .word{display:flex;flex-direction:column;font-weight:800;font-size:1.15rem;color:#fff;line-height:1.05}
.logo .word small{font-weight:600;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
.nav-links{display:flex;align-items:center;gap:1.1rem;list-style:none;margin:0;padding:0}
.nav-links>li{position:relative}
.nav-links a{color:#dfe6f0;font-weight:600;display:block;padding:.5rem 0;white-space:nowrap}
.nav-links a:hover{color:#fff;text-decoration:none}
.nav-links a.active{color:var(--gold)}
.has-sub>a::after{content:" \25BE";font-size:.7em;opacity:.7}
.submenu{list-style:none;margin:0;padding:.4rem 0;position:absolute;top:100%;left:-14px;min-width:250px;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow);display:none}
.submenu a{color:var(--ink);padding:.55rem 1.1rem;font-weight:500}
.submenu a:hover{background:var(--tint);color:var(--red)}
.nav-links>li:hover>.submenu,.nav-links>li:focus-within>.submenu{display:block}
.nav-cta{margin-left:.2rem}
.nav-links a.btn{color:#fff;padding:.55rem 1.2rem}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;font-size:1.7rem;color:#fff}

/* Hero */
.hero{background:linear-gradient(160deg,var(--navy),var(--navy-2));color:#fff;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% -10%,rgba(231,181,59,.18),transparent 55%);pointer-events:none}
.hero h1{color:#fff}
.hero .lead{color:#c4d0e0}
.hero .eyebrow{color:var(--gold)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:2.8rem;align-items:center;padding:3.4rem 0;position:relative;z-index:1}
.hero-solo{padding:3rem 0;max-width:840px;position:relative;z-index:1}
.hero-img img{border-radius:var(--radius);box-shadow:0 12px 32px rgba(0,0,0,.35);width:100%;object-fit:cover;aspect-ratio:3/2}
.page-head{background:linear-gradient(160deg,var(--navy),var(--navy-2));color:#fff;padding:2.8rem 0 1.6rem}
.page-head h1{color:#fff}
.page-head .lead{color:#c4d0e0}
.page-head .eyebrow{color:var(--gold)}

/* Sections */
section{padding:3rem 0}
.section-tint{background:var(--tint)}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:2.4rem;align-items:start}

/* Grid + cards */
.grid{display:grid;gap:1.3rem}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;box-shadow:var(--shadow)}
.card h3{margin-top:0}
.card p{margin-bottom:0;color:var(--muted)}
a.card:hover{text-decoration:none;transform:translateY(-2px);transition:.15s ease;border-color:var(--gold)}
.topic{border-left:4px solid var(--gold)}
.topic h3{color:var(--navy)}
.topic.more{background:var(--navy);border-color:var(--navy)}
.topic.more h3,.topic.more p{color:#fff}
.link-grid .card h3{margin:0;color:var(--red)}

/* Testimonials */
.tm{margin:0 0 1.4rem;padding:1.3rem 1.5rem;background:#fff;border:1px solid var(--line);border-left:4px solid var(--gold);border-radius:12px;box-shadow:var(--shadow)}
.tm p{font-style:italic;margin:0 0 .6rem;color:var(--ink)}
.tm cite{font-style:normal;font-weight:700;color:var(--navy);font-size:.92rem}
.tm cite::before{content:"\2014 "}
.tm-wrap{margin:1.8rem 0}
.reviews-grid{columns:2;column-gap:1.4rem}
.reviews-grid .tm{break-inside:avoid}

/* Seal card */
.seal-card{background:var(--tint);border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;text-align:center}
.seal{width:120px;height:auto;margin:0 auto 1rem}
.seal-card .tm{text-align:left;background:#fff}

/* Lists */
ol.steps{padding-left:1.2rem}
ol.steps li{margin:0 0 1rem;padding-left:.4rem}
ul.check{list-style:none;padding:0}
ul.check li{position:relative;padding:.35rem 0 .35rem 1.9rem}
ul.check li::before{content:"\2726";position:absolute;left:0;color:var(--gold-dark);font-weight:900}
ul.price{list-style:none;padding:0;margin:0 0 1rem}
ul.price li{display:flex;justify-content:space-between;align-items:center;padding:.7rem 0;border-bottom:1px solid var(--line)}
ul.price strong{color:var(--red);font-size:1.2rem}

/* Galleries */
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem;margin:1rem 0 2rem}
.gallery.three{grid-template-columns:repeat(3,1fr)}
.gallery img{border-radius:12px;box-shadow:var(--shadow);width:100%}

/* CTA band */
.cta-band{background:linear-gradient(160deg,var(--navy),var(--navy-2));color:#fff}
.cta-band h2{color:#fff}
.cta-band .lead{color:#c4d0e0}
.cta-actions{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;margin-top:1.2rem}

/* Contact */
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:2.4rem;align-items:start}
.info-row{display:flex;gap:1rem;padding:.7rem 0;border-bottom:1px solid var(--line)}
.info-row .label{min-width:110px;font-weight:700;color:var(--navy)}
.field{margin-bottom:1rem}
.field label{display:block;font-weight:600;margin-bottom:.35rem;font-size:.92rem;color:var(--navy)}
.field input,.field textarea{width:100%;padding:.7rem .8rem;border:1px solid var(--line);border-radius:9px;font:inherit;background:#fff}
.field input:focus,.field textarea:focus{outline:2px solid var(--gold);border-color:var(--gold)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.req{color:var(--red)}
.form-note{min-height:1.2em;margin:.6rem 0 0;font-weight:600}

/* Footer */
.site-footer{background:var(--navy);color:#c4d0e0;padding:2.4rem 0;margin-top:0}
.footer-grid{display:flex;align-items:center;justify-content:space-between;gap:1.4rem;flex-wrap:wrap;padding-bottom:1.2rem;border-bottom:1px solid rgba(255,255,255,.12)}
.footer-links{display:flex;flex-wrap:wrap;gap:1.1rem;list-style:none;margin:0;padding:0}
.footer-links a{color:#c4d0e0;font-weight:600}
.footer-links a:hover{color:#fff}
.footer-small{margin:1.2rem 0 0;font-size:.85rem;color:#8c98a8}
.footer-small a{color:#c4d0e0}

/* Responsive */
@media(max-width:860px){
  .nav-toggle{display:block}
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:var(--navy);padding:.5rem 22px 1rem;border-bottom:2px solid var(--gold)}
  .nav-links.open{display:flex}
  .nav-links>li{width:100%;border-bottom:1px solid rgba(255,255,255,.08)}
  .submenu{position:static;display:block;box-shadow:none;border:0;background:transparent;padding:0 0 .4rem .8rem;min-width:0}
  .submenu a{color:#aebccd}
  .submenu a:hover{background:transparent;color:#fff}
  .nav-cta{margin:.6rem 0 0}
  .nav-links a.btn{display:inline-block}
  .hero-grid,.two-col,.contact-grid{grid-template-columns:1fr}
  .grid-2,.grid-3,.gallery,.gallery.three,.row2{grid-template-columns:1fr}
  .reviews-grid{columns:1}
  .hero-img{order:-1}
}
