/* ===== CannabisSEO.ai — PSYCHEDELIC edition (Wonderland-on-acid) ===== */
:root{
  --grape:#2a0a4a;      /* deep purple base */
  --grape-2:#411680;
  --magenta:#ff2d95;    /* hot pink */
  --acid:#b6ff1f;       /* acid lime */
  --cyan:#16e0e0;       /* electric teal */
  --tangerine:#ff7a18;  /* orange */
  --gold:#ffd23f;       /* yellow */
  --cream:#fdf4ff;      /* near-white, violet tint */
  --ink:#1a0730;        /* deep violet ink */
  --ink-soft:#4a2a6b;
  --line:#e7c7ff;
  --maxw:1200px;
  --display:"Shrikhand",Georgia,serif;
  --sans:"Space Grotesk",system-ui,sans-serif;
  --mono:"Space Mono",ui-monospace,Menlo,monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;color:var(--ink);font-family:var(--sans);font-size:18px;line-height:1.62;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
  background:
    radial-gradient(circle at 12% 8%, rgba(255,45,149,.16), transparent 42%),
    radial-gradient(circle at 88% 14%, rgba(22,224,224,.16), transparent 42%),
    radial-gradient(circle at 50% 96%, rgba(182,255,31,.14), transparent 46%),
    var(--cream);
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
a{color:var(--magenta);text-decoration:none;font-weight:500}
a:hover{color:var(--tangerine)}
img{max-width:100%;height:auto;display:block}

h1,h2,h3,h4{font-family:var(--display);font-weight:400;line-height:1.02;letter-spacing:.005em;color:var(--grape)}
h1{font-size:clamp(3rem,7vw,6rem);margin:0 0 .3em}
h2{font-size:clamp(2.1rem,4.2vw,3.4rem);margin:0 0 .45em}
h3{font-size:1.3rem;margin:0 0 .35em;font-family:var(--sans);font-weight:700;color:var(--ink);letter-spacing:0}
p{margin:0 0 1.1em}
.lead{font-size:1.25rem;color:var(--ink-soft);max-width:64ch}
.hl{background:linear-gradient(105deg,var(--magenta),var(--tangerine),var(--gold));-webkit-background-clip:text;background-clip:text;color:transparent;padding:0 .04em}
.mono{font-family:var(--mono);font-size:.78rem;letter-spacing:.03em;text-transform:uppercase}
.kicker{font-family:var(--mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--magenta);display:inline-block;margin-bottom:1rem;padding:.35em .8em;border:2px solid var(--magenta);border-radius:40px;background:rgba(255,45,149,.08)}

/* ---- buttons: chunky neon pills ---- */
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:var(--mono);font-weight:700;font-size:.82rem;letter-spacing:.03em;text-transform:uppercase;padding:.95em 1.6em;border-radius:50px;border:2px solid var(--ink);transition:transform .12s, box-shadow .12s;box-shadow:4px 4px 0 var(--ink)}
.btn:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink)}
.btn-primary{background:var(--acid);color:var(--ink)}
.btn-ghost{background:var(--cyan);color:var(--ink)}
.btn-wa{background:var(--gold);color:var(--ink)}

/* ---- sections ---- */
.section{padding:5.5rem 0;position:relative}
.section-num{counter-increment:sec}
.section-num h2::before{content:counter(sec,decimal-leading-zero) " / ";color:var(--magenta);font-family:var(--mono);font-size:.5em;vertical-align:.5em;font-weight:700}
body{counter-reset:sec}
.divider{height:6px;background:repeating-linear-gradient(90deg,var(--magenta) 0 22px,var(--gold) 22px 44px,var(--cyan) 44px 66px,var(--acid) 66px 88px)}

/* ---- header ---- */
header.site{position:sticky;top:0;z-index:40;background:rgba(253,244,255,.9);backdrop-filter:blur(10px);border-bottom:3px solid var(--ink)}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px}
.brand{display:flex;align-items:center;gap:.55rem;font-family:var(--display);font-size:1.4rem;color:var(--grape)}
.brand .leaf{width:32px;height:32px;color:var(--magenta);animation:spin 14s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.menu{display:flex;align-items:center;gap:1.5rem;list-style:none;margin:0;padding:0}
.menu a{font-family:var(--mono);font-size:.75rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--grape)}
.menu a:hover{color:var(--magenta)}
.has-drop{position:relative}
.has-drop>a::after{content:" ▾";color:var(--magenta)}
.drop{position:absolute;top:100%;left:-1rem;min-width:240px;background:var(--grape);border:3px solid var(--ink);border-radius:14px;padding:.5rem;opacity:0;visibility:hidden;transform:translateY(8px);transition:.16s;box-shadow:8px 8px 0 var(--magenta)}
.has-drop::after{content:"";position:absolute;top:100%;left:0;width:100%;height:20px}
.has-drop:hover .drop,.has-drop:focus-within .drop{opacity:1;visibility:visible;transform:translateY(0)}
.drop a{display:block;padding:.55rem .7rem;font-size:.72rem;color:var(--cream);border-radius:8px}
.drop a:hover{background:var(--magenta);color:#fff}
.nav-cta{display:flex;gap:.6rem;align-items:center}

/* ---- hero ---- */
.hero{position:relative;padding:7rem 0 6rem;overflow:hidden;min-height:84vh;display:flex;align-items:center;
  background:linear-gradient(120deg,#2a0a4a,#7d1a8f,#ff2d95,#ff7a18,#2a0a4a);background-size:400% 400%;animation:flow 18s ease infinite}
@keyframes flow{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.hero .wrap,.hero-inner{position:relative;z-index:2}
.hero-inner{max-width:920px}
.hero .kicker{color:#fff;border-color:#fff;background:rgba(255,255,255,.12)}
.hero h1{color:#fff;text-shadow:3px 3px 0 var(--grape), 6px 6px 0 rgba(0,0,0,.25)}
.hero .lead{color:rgba(255,255,255,.94);font-size:1.32rem;margin-top:1.4rem;max-width:60ch}
.hero .note{font-family:var(--mono);font-size:.82rem;color:#fff;background:rgba(26,7,48,.4);border-left:4px solid var(--acid);padding:.9rem 1rem;margin:1.8rem 0;max-width:62ch;border-radius:0 10px 10px 0}
.hero-cta{display:flex;gap:.9rem;flex-wrap:wrap;margin-top:2.2rem}

/* drifting, hue-shifting, melting leaves */
.leaves{position:absolute;inset:0;pointer-events:none;z-index:1;overflow:hidden}
.leaves .lf{position:absolute;top:-14%;color:var(--acid);opacity:0;filter:drop-shadow(0 0 6px rgba(255,255,255,.4));animation:drift var(--d,30s) linear infinite;animation-delay:var(--delay,0s)}
@keyframes drift{
  0%{transform:translateY(-15vh) rotate(0deg) scale(1);opacity:0;filter:hue-rotate(0deg) drop-shadow(0 0 6px rgba(255,255,255,.4))}
  10%{opacity:.9}
  50%{transform:translateY(45vh) rotate(220deg) scale(1.25);filter:hue-rotate(180deg) drop-shadow(0 0 10px rgba(255,255,255,.5))}
  90%{opacity:.9}
  100%{transform:translateY(120vh) rotate(520deg) scale(.9);opacity:0;filter:hue-rotate(360deg) drop-shadow(0 0 6px rgba(255,255,255,.4))}
}
@media(prefers-reduced-motion:reduce){.leaves .lf{animation:none;opacity:.5}.hero{animation:none}.brand .leaf{animation:none}}

/* ---- AI band (deep trippy) ---- */
.ai-band{background:radial-gradient(circle at 20% 20%, rgba(255,45,149,.35), transparent 45%),radial-gradient(circle at 85% 70%, rgba(22,224,224,.32), transparent 45%),var(--grape);color:var(--cream);border-top:6px solid var(--acid);border-bottom:6px solid var(--magenta)}
.ai-band h2{color:#fff;text-shadow:2px 2px 0 var(--magenta)}
.ai-band .lead,.ai-band p{color:rgba(253,244,255,.92)}
.ai-band .kicker{color:var(--acid);border-color:var(--acid);background:rgba(182,255,31,.1)}
.ai-chips{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.4rem}
.ai-chips span{font-family:var(--mono);font-size:.78rem;font-weight:700;padding:.5em 1em;border-radius:40px;border:2px solid var(--cyan);color:var(--cyan)}

/* ---- pieces / cards ---- */
.grid{display:grid;gap:1.2rem}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
.piece{background:#fff;padding:2rem 1.7rem;border:3px solid var(--ink);border-radius:18px;box-shadow:6px 6px 0 var(--grape);transition:transform .14s,box-shadow .14s}
.piece:nth-child(3n+1){box-shadow:6px 6px 0 var(--magenta)}
.piece:nth-child(3n+2){box-shadow:6px 6px 0 var(--cyan)}
.piece:nth-child(3n){box-shadow:6px 6px 0 var(--tangerine)}
.piece:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--grape)}
.piece .pn{font-family:var(--mono);font-weight:700;font-size:.72rem;color:var(--magenta);letter-spacing:.1em}
.piece h3{margin-top:.5rem}

/* ---- constats ---- */
.constats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.constat{background:var(--grape);color:var(--cream);border:3px solid var(--ink);border-radius:18px;padding:1.6rem 1.3rem;box-shadow:6px 6px 0 var(--acid)}
.constat:nth-child(2){box-shadow:6px 6px 0 var(--magenta)}
.constat:nth-child(3){box-shadow:6px 6px 0 var(--cyan)}
.constat:nth-child(4){box-shadow:6px 6px 0 var(--gold)}
.constat .big{font-family:var(--display);font-size:2.9rem;color:var(--gold);line-height:1}
.constat:nth-child(2) .big{color:var(--cyan)}
.constat:nth-child(3) .big{color:var(--acid)}
.constat:nth-child(4) .big{color:var(--magenta)}
.constat .lbl{font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.03em;color:rgba(253,244,255,.82);margin-top:.5rem}
.constat .cn{font-family:var(--mono);font-size:.64rem;color:var(--acid);letter-spacing:.1em}

/* ---- accordions ---- */
details{border:3px solid var(--ink);border-radius:14px;margin:.7rem 0;background:#fff;overflow:hidden}
summary{cursor:pointer;list-style:none;padding:1.1rem 1.2rem;font-family:var(--sans);font-weight:700;font-size:1.12rem;color:var(--grape);display:flex;justify-content:space-between;gap:1rem;align-items:center}
summary::-webkit-details-marker{display:none}
summary::after{content:"✦";color:var(--magenta);font-size:1.2rem;transition:transform .2s}
details[open] summary::after{transform:rotate(180deg);color:var(--tangerine)}
details[open] summary{background:var(--acid)}
details .body{padding:0 1.2rem 1.3rem;color:var(--ink-soft);max-width:80ch}
.panorama li{margin:.35rem 0}

/* ---- CTA band ---- */
.cta-band{border:4px solid var(--ink);border-radius:26px;position:relative;padding:3.2rem 2.5rem;text-align:center;
  background:linear-gradient(120deg,var(--magenta),var(--tangerine),var(--gold),var(--cyan));background-size:300% 300%;animation:flow 12s ease infinite;box-shadow:10px 10px 0 var(--grape)}
.cta-band .cta-title{font-family:var(--display);font-size:clamp(2rem,4vw,3.2rem);color:var(--grape);margin:0 0 .4rem;text-shadow:2px 2px 0 rgba(255,255,255,.55)}
.cta-band p{color:var(--ink);font-weight:600}

/* ---- footer ---- */
footer.site{background:var(--grape);color:rgba(253,244,255,.82);padding:3.5rem 0 2rem;font-size:.92rem;border-top:6px solid var(--acid)}
footer.site a{color:rgba(253,244,255,.82)}
footer.site a:hover{color:var(--acid)}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:2rem;}
.foot-grid-4{grid-template-columns:1.7fr 1fr 1fr 1fr;border-bottom:2px solid rgba(253,244,255,.18);padding-bottom:2rem}
.foot-brand{display:flex;align-items:center;gap:.5rem;font-family:var(--display);font-size:1.3rem;color:#fff}
.foot-brand .leaf{color:var(--magenta)}
.foot-col .foot-h{margin:0 0 .8rem;font-family:var(--mono);font-weight:700;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--acid)}
.foot-col a{display:block;margin:.35rem 0;font-size:.85rem}
.foot-bot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;padding-top:1.4rem;font-family:var(--mono);font-size:.7rem;letter-spacing:.03em;color:rgba(253,244,255,.6)}

@media(max-width:980px){
  .hero-inner{max-width:100%}
  .grid.cols-3,.grid.cols-2{grid-template-columns:1fr}
  .constats{grid-template-columns:repeat(2,1fr)}
  .menu{display:none}.foot-grid{grid-template-columns:1fr}
}

/* ===== service pages ===== */
.svc-hero{min-height:auto;padding:3.2rem 0 4.5rem}
.crumb{position:relative;z-index:2;font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:#fff;margin-bottom:1.6rem}
.crumb a{color:var(--acid)}
.crumb span{color:rgba(255,255,255,.5);margin:0 .3rem}
.svc-hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:2.5rem;align-items:center;position:relative;z-index:2}
.svc-hero .hero-inner{max-width:none}
.svc-hero h1{font-size:clamp(2.4rem,5vw,4rem)}
.img-slot{margin:0}
.img-slot img{border:4px solid var(--ink);border-radius:20px;box-shadow:8px 8px 0 var(--acid);width:100%;max-width:440px;aspect-ratio:3/4;object-fit:cover;height:auto;margin-inline:auto}
.img-ph{aspect-ratio:3/4;max-width:440px;margin-inline:auto;border:3px dashed rgba(255,255,255,.6);border-radius:20px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:#fff;background:rgba(26,7,48,.28)}
.img-ph span{font-family:var(--mono);font-size:.78rem;text-align:center;line-height:1.5;opacity:.9}
.related{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.5rem}
.rel-chip{font-family:var(--mono);font-weight:700;font-size:.82rem;padding:.7em 1.2em;border-radius:40px;border:2px solid var(--ink);background:#fff;color:var(--grape);box-shadow:4px 4px 0 var(--magenta);transition:transform .12s,box-shadow .12s}
.rel-chip:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--magenta);color:var(--magenta)}
@media(max-width:900px){.svc-hero-grid{grid-template-columns:1fr}.img-slot{max-width:460px}}

.piece .learn{display:inline-block;margin-top:.7rem;font-family:var(--mono);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--magenta)}
.piece .learn:hover{color:var(--tangerine)}
.piece h3 a{color:inherit}
.piece h3 a:hover{color:var(--magenta)}

/* ===== hero background video ===== */
.hero.has-video{background:#2a0a4a}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;pointer-events:none}
.hero-overlay{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(120deg, rgba(42,10,74,.82), rgba(125,26,143,.5) 45%, rgba(42,10,74,.8));
  mix-blend-mode:normal}
.hero.has-video .leaves{z-index:1}
.hero.has-video .wrap{position:relative;z-index:2}
@media(prefers-reduced-motion:reduce){.hero-video{display:none}}

/* ===== home hero: framed video on the right ===== */
.hero-grid2{display:grid;grid-template-columns:1.12fr .88fr;gap:2.6rem;align-items:start}
.hero-grid2 .hero-inner{max-width:none}
.hero-media{margin:0}
.hero-grid2 .hero-media{margin-top:2.7rem}
.hero-vid-frame{display:block;width:100%;max-width:400px;aspect-ratio:3/4;object-fit:cover;border:4px solid var(--ink);border-radius:20px;box-shadow:10px 10px 0 var(--acid);margin-inline:auto}
@media(max-width:900px){.hero-grid2{grid-template-columns:1fr}.hero-grid2 .hero-media{margin-top:0}.hero-vid-frame{max-width:340px;margin-top:1rem}}

/* ===== cookie consent banner ===== */
.foot-legal a{color:rgba(253,244,255,.7)}
.foot-legal a:hover{color:var(--acid)}
.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:80;max-width:760px;margin:0 auto;
  background:var(--grape);color:var(--cream);border:3px solid var(--ink);border-radius:16px;
  box-shadow:8px 8px 0 var(--magenta);padding:1.1rem 1.3rem;display:flex;gap:1rem;align-items:center;flex-wrap:wrap;justify-content:space-between}
.cookie-banner p{margin:0;font-size:.9rem;flex:1 1 320px;color:rgba(253,244,255,.92)}
.cookie-banner a{color:var(--acid)}
.cookie-banner .cc-actions{display:flex;gap:.6rem;flex-wrap:wrap}
.cookie-banner .btn{box-shadow:none;padding:.7em 1.2em}
.cookie-banner[hidden]{display:none}

/* ===== legal + about pages ===== */
.doc{max-width:820px;margin:0 auto;padding:3.5rem 0}
.doc h2{font-size:1.7rem;margin-top:2.2rem}
.doc h3{margin-top:1.4rem}
.doc p,.doc li{color:var(--ink-soft)}
.doc ul{padding-left:1.2rem}
.doc .updated{font-family:var(--mono);font-size:.78rem;color:var(--magenta);text-transform:uppercase;letter-spacing:.06em}
.ph{background:linear-gradient(transparent 55%, var(--gold) 55%);padding:0 .15em;border-radius:2px;color:var(--ink);font-weight:600}
.doc table{border-collapse:collapse;width:100%;margin:1rem 0;font-size:.9rem}
.doc th,.doc td{border:2px solid var(--ink);padding:.6rem .7rem;text-align:left}
.doc th{background:var(--acid);font-family:var(--mono);font-size:.78rem;text-transform:uppercase}
.doc .note{background:var(--paper-2);border-left:4px solid var(--magenta);padding:.9rem 1.1rem;border-radius:0 10px 10px 0;margin:1.2rem 0}
/* about */
.about-hero{padding:3.5rem 0 2rem}
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:2.5rem;align-items:start}
.about-grid .img-ph,.about-grid img{aspect-ratio:3/4;max-width:380px}
.about-grid img{width:100%;border:4px solid var(--ink);border-radius:20px;box-shadow:10px 10px 0 var(--cyan);object-fit:cover}
@media(max-width:860px){.about-grid{grid-template-columns:1fr}}

.img-slot video.svc-vid{display:block;width:100%;max-width:440px;aspect-ratio:3/4;object-fit:cover;border:4px solid var(--ink);border-radius:20px;box-shadow:8px 8px 0 var(--acid);margin-inline:auto}
