/* ===================================================================
   Poppa Prints — shared studio-page styles.
   Each page sets its filament color with:  <style>:root{--c:#23c4ef}</style>
   =================================================================== */
:root{
  --bg:#0a0b11; --bg2:#12141d; --surf:#161925; --line:#262a3a;
  --paper:#f1f3f9; --mute:#9aa3bd;
  --rainbow:linear-gradient(90deg,#ff2d75,#ff6a1a,#ffd23f,#19c37d,#23c4ef,#6a5cff,#c44cff);
  --c:#23c4ef;                 /* default; overridden per studio */
}
*{margin:0;padding:0;box-sizing:border-box}
body{background:var(--bg);color:var(--paper);
  font-family:'Helvetica Neue',Arial,sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 26px}

.filament{height:5px;background:var(--rainbow);background-size:200% auto;animation:flow 6s linear infinite}
@keyframes flow{to{background-position:200% center}}

/* nav */
nav{display:flex;justify-content:space-between;align-items:center;padding:18px 0;position:sticky;top:0;
  background:rgba(10,11,17,.82);backdrop-filter:blur(10px);z-index:50;border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:11px;font-weight:800;font-size:18px;letter-spacing:.01em}
.brand .bx{width:28px;height:28px;border-radius:7px;background:var(--rainbow);background-size:200% auto;
  animation:flow 6s linear infinite;clip-path:polygon(50% 2%,98% 27%,98% 73%,50% 98%,2% 73%,2% 27%)}
.brand small{color:var(--mute);font-weight:600;font-size:12px;margin-left:2px}
.navlinks{display:flex;gap:20px;align-items:center}
.navlink{font-size:13px;color:var(--mute);font-weight:600}.navlink:hover{color:var(--paper)}
.btn{border:none;cursor:pointer;font:inherit;font-weight:700;border-radius:9px;padding:11px 18px;font-size:13px;
  transition:transform .15s,box-shadow .15s}
.btn:hover{transform:translateY(-2px)}
.btn-p{background:var(--c);color:#0a0b11;box-shadow:0 6px 22px color-mix(in srgb,var(--c) 38%,transparent)}
.btn-o{background:var(--bg2);color:var(--paper);border:1px solid var(--line)}

/* hero */
.hero{position:relative;padding:74px 0 66px;border-bottom:1px solid var(--line);overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;z-index:0;
  background:radial-gradient(620px 380px at 82% 14%,color-mix(in srgb,var(--c) 26%,transparent),transparent 60%),
    radial-gradient(520px 320px at 10% 90%,rgba(106,92,255,.10),transparent 60%)}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:center}
.badge{display:inline-flex;align-items:center;gap:8px;background:var(--bg2);border:1px solid var(--line);
  border-radius:30px;padding:8px 15px;font-size:12px;color:var(--paper);font-weight:700;letter-spacing:.04em;margin-bottom:24px}
.badge .dot{width:8px;height:8px;border-radius:50%;background:var(--c)}
h1{font-size:clamp(38px,6vw,66px);line-height:1.0;font-weight:800;letter-spacing:-.035em}
.hl{color:var(--c)}
.sub{font-size:19px;color:#c3cbe1;line-height:1.55;margin-top:22px;max-width:560px}
.hero-cta{margin-top:30px;display:flex;gap:13px;flex-wrap:wrap}
.b-lg{padding:15px 26px;font-size:15px;border-radius:10px}

/* swirling rainbow hex (brand mark) with studio-colored glow */
.hexwrap{position:relative;display:flex;justify-content:center;align-items:center}
.hexwrap::after{content:"";position:absolute;width:78%;height:78%;border-radius:50%;
  background:radial-gradient(circle,color-mix(in srgb,var(--c) 45%,transparent),transparent 70%);filter:blur(30px);z-index:0}
.hex{position:relative;z-index:1;width:min(320px,76vw);aspect-ratio:1/1.04;overflow:hidden;
  clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%)}
.hex .wheel{position:absolute;inset:-38%;animation:spin 18s linear infinite;
  background:conic-gradient(from 0deg,#ff2d75,#ff6a1a,#ffd23f,#19c37d,#23c4ef,#6a5cff,#c44cff,#ff2d75);filter:saturate(1.15)}
.hex .layers{position:absolute;inset:0;background:repeating-linear-gradient(0deg,rgba(8,9,15,.30) 0 1.5px,transparent 1.5px 11px)}
.hex .gloss{position:absolute;inset:0;background:linear-gradient(125deg,rgba(255,255,255,.22),transparent 42%)}
@keyframes spin{to{transform:rotate(360deg)}}

section{padding:72px 0;border-bottom:1px solid var(--line)}
.eyebrow{font-size:12px;letter-spacing:.26em;text-transform:uppercase;font-weight:700;margin-bottom:13px;color:var(--c)}
h2{font-size:clamp(27px,4.2vw,42px);font-weight:800;letter-spacing:-.025em;line-height:1.08}
.lede{color:#c3cbe1;font-size:18px;line-height:1.55;max-width:640px;margin-top:13px}

/* product grid */
.prods{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:42px}
.p{position:relative;background:var(--bg2);border:1px solid var(--line);border-radius:15px;padding:26px;overflow:hidden;
  transition:border-color .2s,transform .2s,box-shadow .2s}
.p::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--c)}
.p:hover{transform:translateY(-4px);border-color:var(--c);box-shadow:0 16px 38px color-mix(in srgb,var(--c) 26%,transparent)}
.p .tag{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--c)}
.p h3{font-size:19px;margin:12px 0 8px;font-weight:800;letter-spacing:-.01em}
.p .desc{color:var(--mute);font-size:14.5px;line-height:1.5}
.p .price{margin-top:16px;font-weight:800;font-size:16px;color:var(--c)}
.p .price small{color:var(--mute);font-weight:600;font-size:13px}

/* steps */
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);
  border-radius:14px;overflow:hidden;margin-top:42px}
.fl{background:var(--bg2);padding:28px 22px}
.fl .n{font-family:'SF Mono',monospace;font-size:13px;color:var(--c);font-weight:700;letter-spacing:.1em}
.fl h4{font-size:17px;margin:11px 0 7px;font-weight:800}.fl p{color:var(--mute);font-size:14px;line-height:1.5}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px;margin-top:40px;align-items:start}
.callcard{background:var(--surf);border:1px solid var(--line);border-radius:18px;padding:30px}
.callcard .big{font-size:22px;font-weight:800}
.callcard p{color:var(--mute);margin-top:10px;line-height:1.6}
.callcard a.tel{display:inline-block;margin-top:16px;font-size:20px;font-weight:800;color:var(--c)}
form{background:var(--bg2);border:1px solid var(--line);border-radius:18px;padding:28px}
form label{display:block;font-size:12px;color:var(--mute);margin:13px 0 5px;letter-spacing:.04em}
form input,form select,form textarea{width:100%;padding:12px;border-radius:9px;border:1px solid var(--line);
  background:var(--bg);color:var(--paper);font-size:15px;font-family:inherit}
form input:focus,form select:focus,form textarea:focus{outline:none;border-color:var(--c)}
.two{display:flex;gap:11px}.two>div{flex:1}
.sub-btn{width:100%;margin-top:18px;padding:15px;font-size:15px;border-radius:11px}
#pp-msg{margin:12px 0 0;font-size:14px;min-height:18px}

footer{padding:36px 0;color:var(--mute);font-size:13px;text-align:center;line-height:1.8}
footer b{color:var(--paper)}footer a{color:var(--c);font-weight:700}

@media (prefers-reduced-motion: reduce){*{animation:none !important}}
@media(max-width:900px){.hero-grid{grid-template-columns:1fr}.hexwrap{order:-1}
  .prods,.flow{grid-template-columns:1fr 1fr}.contact-grid{grid-template-columns:1fr}}
@media(max-width:600px){.navlinks .navlink{display:none}.prods,.flow{grid-template-columns:1fr}}
