/* ===========================================================
   Summit Prints — stylesheet
   Palette: deep navy + brand red accent (matches the logo)
   Note: --gold / --gold-deep are the accent tokens (now red),
   kept under these names so every existing reference updates at once.
   =========================================================== */
:root{
    --navy:        #1e2a63;
    --navy-2:      #16264a;
    --navy-soft:   #1d2f57;
    --gold:        #d8232a;   /* brand red */
    --gold-deep:   #b01c22;   /* darker red (hover) */
    --gold-soft:   #ef5158;   /* lighter red for text on dark */
    --ink:         #1d2433;
    --body:        #4a5568;
    --muted:       #8a93a6;
    --line:        #e6e9f0;
    --bg:          #ffffff;
    --bg-alt:      #f6f8fc;
    --white:       #ffffff;
    --radius:      14px;
    --radius-sm:   10px;
    --shadow:      0 18px 45px -22px rgba(14,27,51,.45);
    --shadow-sm:   0 8px 24px -14px rgba(14,27,51,.4);
    --max:         1180px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
    font-family:'Poppins',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
    color:var(--body);
    background:var(--bg);
    line-height:1.65;
    font-size:16px;
    -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;color:var(--ink);line-height:1.18;font-weight:700}
a{color:inherit;text-decoration:none;transition:.2s}
img{max-width:100%;display:block}
.container{width:100%;max-width:var(--max);margin:0 auto;padding:0 22px}
section{padding:86px 0}

/* ---------- Buttons ---------- */
.btn{
    display:inline-block;border:none;cursor:pointer;font-family:inherit;
    font-weight:600;font-size:.95rem;padding:14px 30px;border-radius:50px;
    transition:.22s;letter-spacing:.2px;
}
.btn-accent{background:var(--gold);color:#fff}
.btn-accent:hover{background:var(--gold-deep);transform:translateY(-2px)}
.btn-outline{background:transparent;border:2px solid var(--white);color:var(--white)}
.btn-outline:hover{background:var(--white);color:var(--navy)}
.btn-dark{background:var(--navy);color:#fff}
.btn-dark:hover{background:var(--navy-2);transform:translateY(-2px)}

/* ---------- Header ---------- */
.site-header{
    position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);
    backdrop-filter:blur(8px);border-bottom:1px solid var(--line);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:10px;color:var(--navy)}
.site-logo{display:block;width:auto;height:auto}
.header-inner .site-logo{height:48px}
.footer-logo .site-logo{height:50px;margin-bottom:6px}
/* PNG logo has navy text — whiten it on the dark footer so it stays visible */
.site-logo--light{filter:brightness(0) invert(1)}

.main-nav ul{list-style:none;display:flex;align-items:center;gap:6px}
.main-nav a{padding:10px 16px;border-radius:8px;font-weight:500;color:var(--ink);font-size:.96rem}
.main-nav a:hover,.main-nav a.active{color:var(--gold-deep)}
.main-nav .btn-quote{background:var(--navy);color:#fff!important;border-radius:50px;padding:11px 22px}
.main-nav .btn-quote:hover{background:var(--gold);color:#fff!important}

.has-dropdown{position:relative}
.dropdown{
    position:absolute;top:130%;left:0;min-width:180px;background:#fff;
    border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-sm);
    padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.2s;display:block;
}
.has-dropdown:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown li{width:100%}
.dropdown a{display:block;border-radius:8px}
.dropdown a:hover{background:var(--bg-alt)}

.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.nav-toggle span{width:26px;height:3px;background:var(--navy);border-radius:3px;transition:.3s}

/* ---------- Hero ---------- */
.hero{
    position:relative;color:#fff;overflow:hidden;
    background:radial-gradient(900px 500px at 80% -10%,rgba(216,35,42,.22),transparent 60%),
               linear-gradient(135deg,var(--navy) 0%,var(--navy-2) 60%,var(--navy-soft) 100%);
    padding:104px 0 110px;
}
.hero::after{
    content:"";position:absolute;inset:0;opacity:.06;pointer-events:none;
    background-image:repeating-linear-gradient(45deg,#fff 0 2px,transparent 2px 14px);
}
.hero-inner{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center}
.hero .eyebrow{display:inline-block;color:var(--gold-soft);font-weight:600;letter-spacing:3px;text-transform:uppercase;font-size:.78rem;margin-bottom:18px}
.hero h1{color:#fff;font-size:3.3rem;font-weight:800;margin-bottom:18px}
.hero h1 em{color:var(--gold);font-style:normal}
.hero p.lead{font-size:1.12rem;color:#c8d1e4;max-width:520px;margin-bottom:30px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-badge{display:flex;gap:26px;margin-top:38px;flex-wrap:wrap}
.hero-badge div{display:flex;flex-direction:column}
.hero-badge b{font-family:'Playfair Display',serif;font-size:1.7rem;color:#fff}
.hero-badge small{color:#9fb0d0;font-size:.82rem;letter-spacing:.5px}

.hero-visual{position:relative}
.hero-card{
    background:linear-gradient(160deg,#ffffff,#eef2fb);border-radius:22px;
    box-shadow:0 30px 60px -25px rgba(0,0,0,.6);padding:26px;transform:rotate(-2deg);
}
.hoop{aspect-ratio:1;border-radius:50%;background:
    repeating-radial-gradient(circle at 50% 50%,#173058 0 7px,#1f3d6e 7px 9px);
    display:flex;align-items:center;justify-content:center;border:10px solid var(--gold);
    box-shadow:inset 0 0 40px rgba(0,0,0,.4)}
.hoop span{font-family:'Playfair Display',serif;color:var(--gold-soft);font-size:2.6rem;font-weight:800;text-align:center;line-height:1.1;text-shadow:0 2px 6px rgba(0,0,0,.4)}

/* ---------- Section heading ---------- */
.sec-head{text-align:center;max-width:680px;margin:0 auto 54px}
.sec-head .kicker{color:var(--gold-deep);font-weight:600;letter-spacing:2px;text-transform:uppercase;font-size:.8rem}
.sec-head h2{font-size:2.4rem;margin:10px 0 14px}
.sec-head p{color:var(--muted)}

/* ---------- Services ---------- */
.bg-alt{background:var(--bg-alt)}
/* ----- Service tiles (2x2, upright vertical title threaded on the box edge) ----- */
.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:40px}
.service-card{
    position:relative;min-height:288px;background:#fff;
    border:1px solid var(--line);border-radius:20px;transition:.32s cubic-bezier(.2,.7,.2,1);
}
/* soft brand glow, mirrored toward the outer corner */
.service-card::before{content:"";position:absolute;inset:0;border-radius:20px;pointer-events:none;transition:.32s;
    background:radial-gradient(260px 260px at 0 0,rgba(216,35,42,.09),transparent 62%)}
.service-card:nth-child(odd)::before{background:radial-gradient(260px 260px at 100% 0,rgba(216,35,42,.09),transparent 62%)}
.service-card:hover{transform:translateY(-7px);box-shadow:var(--shadow)}

.sc-num{position:absolute;top:14px;font-family:'Playfair Display',serif;font-weight:800;
    font-size:4.4rem;line-height:1;color:var(--ink);opacity:.05;z-index:0}
.service-card:nth-child(odd) .sc-num{left:26px}
.service-card:nth-child(even) .sc-num{right:26px}

.sc-body{position:relative;z-index:2;padding:34px 30px;display:flex;flex-direction:column;align-items:flex-start;height:100%}
.service-card:nth-child(odd)  .sc-body{padding-right:54px}
.service-card:nth-child(even) .sc-body{padding-left:54px}
.service-ico{width:60px;height:60px;border-radius:16px;background:rgba(216,35,42,.12);color:var(--gold-deep);
    display:flex;align-items:center;justify-content:center;margin-bottom:18px;transition:.3s}
.service-card:hover .service-ico{background:var(--gold);color:#fff;transform:rotate(-6deg)}
.service-card h3{font-size:1.32rem;margin-bottom:10px}
.service-card p{font-size:.95rem;color:var(--body);margin-bottom:18px}
.sc-link{margin-top:auto;font-weight:600;font-size:.92rem;color:var(--gold-deep);display:inline-flex;align-items:center;gap:7px}
.sc-link span{transition:.25s}
.sc-link:hover span{transform:translateX(5px)}

/* upright vertical title sitting ON the inner box line (no separate band) */
.sc-label{position:absolute;top:50%;z-index:3;text-decoration:none;line-height:1;transition:.3s}
.sc-label span{writing-mode:vertical-rl;text-orientation:upright;font-family:'Playfair Display',serif;font-weight:800;
    font-size:1.42rem;letter-spacing:1px;text-transform:uppercase;color:var(--navy);transition:.3s}
.service-card:nth-child(odd)  .sc-label{right:0;transform:translate(50%,-50%)}
.service-card:nth-child(even) .sc-label{left:0; transform:translate(-50%,-50%)}
.service-card:hover .sc-label span{color:var(--gold)}

/* ---------- Why choose us ---------- */
.why{background:
    linear-gradient(135deg,var(--navy),var(--navy-2));color:#fff}
.why .sec-head h2{color:#fff}
.why .sec-head .kicker{color:var(--gold-soft)}
.why .sec-head p{color:#aebbd6}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.why-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);border-radius:var(--radius);padding:26px;display:flex;gap:16px;align-items:flex-start;transition:.25s}
.why-card:hover{background:rgba(255,255,255,.09);transform:translateY(-4px)}
.why-num{flex:none;width:46px;height:46px;border-radius:12px;background:var(--gold);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-family:'Playfair Display',serif}
.why-card h3{color:#fff;font-size:1.08rem;margin-bottom:4px}
.why-card p{color:#aebbd6;font-size:.9rem}

/* ---------- Stats ---------- */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat{text-align:center;padding:30px 18px;border-radius:var(--radius);background:#fff;border:1px solid var(--line)}
.stat b{display:block;font-family:'Playfair Display',serif;font-size:2.8rem;color:var(--navy);font-weight:800}
.stat b::after{content:"+";color:var(--gold)}
.stat span{color:var(--muted);font-weight:500;letter-spacing:.4px}

/* ---------- Testimonials ---------- */
.tst-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.tst-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-sm);position:relative}
.tst-card .quote{font-size:3rem;font-family:'Playfair Display',serif;color:var(--gold);line-height:.6;height:24px}
.tst-card p{color:var(--ink);font-size:1rem;margin:14px 0 22px}
.tst-stars{color:var(--gold);letter-spacing:2px;margin-bottom:14px}
.tst-author{display:flex;align-items:center;gap:12px}
.tst-avatar{width:46px;height:46px;border-radius:50%;background:var(--navy);color:var(--gold-soft);display:flex;align-items:center;justify-content:center;font-weight:700;font-family:'Playfair Display',serif}
.tst-author b{color:var(--ink);font-family:'Poppins',sans-serif;font-size:.95rem;display:block}
.tst-author small{color:var(--muted)}

/* ---------- CTA strip ---------- */
.cta{background:linear-gradient(120deg,var(--gold),var(--gold-deep));text-align:center}
.cta h2{font-size:2.3rem;margin-bottom:10px;color:#fff}
.cta p{color:rgba(255,255,255,.92);max-width:560px;margin:0 auto 26px;font-weight:500}

/* ---------- Quote / Contact forms ---------- */
.form-wrap{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:start}
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow-sm)}
.field{margin-bottom:18px}
.field label{display:block;font-weight:500;color:var(--ink);margin-bottom:7px;font-size:.92rem}
.field input,.field select,.field textarea{
    width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:var(--radius-sm);
    font-family:inherit;font-size:.95rem;color:var(--ink);background:var(--bg-alt);transition:.2s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);background:#fff;box-shadow:0 0 0 3px rgba(216,35,42,.18)}
.field textarea{min-height:130px;resize:vertical}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.info-list{list-style:none}
.info-list li{display:flex;gap:16px;align-items:flex-start;margin-bottom:24px}
.info-ico{flex:none;width:50px;height:50px;border-radius:13px;background:var(--navy);color:var(--gold-soft);display:flex;align-items:center;justify-content:center}
.info-list h4{color:var(--ink);font-family:'Poppins',sans-serif;font-size:1rem;margin-bottom:2px}
.info-list p,.info-list a{color:var(--body);font-size:.95rem}
.info-list a:hover{color:var(--gold-deep)}

.alert{padding:14px 18px;border-radius:var(--radius-sm);margin-bottom:22px;font-size:.95rem}
.alert-success{background:#e7f6ec;color:#1d7a3f;border:1px solid #bce6cb}
.alert-error{background:#fdecec;color:#b3261e;border:1px solid #f3c4c1}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{background:linear-gradient(135deg,var(--navy),var(--navy-2));color:#fff;text-align:center;padding:74px 0}
.page-hero h1{color:#fff;font-size:2.7rem}
.page-hero p{color:#aebbd6;margin-top:10px}
.crumbs{margin-top:16px;color:#8ea0c4;font-size:.9rem}
.crumbs a{color:var(--gold-soft)}

/* ---------- About ---------- */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.about-grid .lead{font-size:1.1rem;color:var(--ink);margin-bottom:18px}
.about-visual{background:linear-gradient(160deg,var(--navy),var(--navy-2));border-radius:var(--radius);aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;color:var(--gold-soft);box-shadow:var(--shadow)}
.check-list{list-style:none;margin-top:18px}
.check-list li{padding-left:30px;position:relative;margin-bottom:12px;color:var(--ink)}
.check-list li::before{content:"\2713";position:absolute;left:0;top:0;width:20px;height:20px;background:var(--gold);color:#fff;border-radius:50%;font-size:.72rem;display:flex;align-items:center;justify-content:center;font-weight:700}

/* ---------- Portfolio ---------- */
.pf-tabs{display:flex;gap:10px;justify-content:center;margin-bottom:40px;flex-wrap:wrap}
.pf-tab{padding:11px 24px;border-radius:50px;border:1px solid var(--line);background:#fff;font-weight:500;color:var(--ink);cursor:pointer}
.pf-tab.active,.pf-tab:hover{background:var(--navy);color:#fff;border-color:var(--navy)}
.pf-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.pf-item{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:#fff;transition:.25s}
.pf-item:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.pf-thumb{aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;color:#fff;font-family:'Playfair Display',serif;font-size:1.3rem;text-align:center;padding:16px}
.pf-body{padding:18px}
.pf-body h4{font-family:'Poppins',sans-serif;font-size:1rem;color:var(--ink)}
.pf-body span{color:var(--muted);font-size:.85rem}

/* ---------- Design Studio ---------- */
.studio-hero{background:linear-gradient(135deg,var(--navy),var(--navy-2));color:#fff;text-align:center;padding:42px 0}
.studio-hero h1{color:#fff;font-size:2rem}
.studio-hero p{color:#aebbd6;margin-top:6px;font-size:.96rem}

.studio{display:flex;align-items:stretch;background:#fff;border-bottom:1px solid var(--line);min-height:640px}
.studio-rail{flex:none;width:88px;background:var(--navy);display:flex;flex-direction:column;padding:10px 0}
.rail-btn{display:flex;flex-direction:column;align-items:center;gap:5px;background:none;border:none;color:#aebbd6;cursor:pointer;padding:14px 4px;font-size:.72rem;font-weight:500;border-left:3px solid transparent;transition:.2s}
.rail-btn svg{width:24px;height:24px}
.rail-btn:hover{color:#fff;background:rgba(255,255,255,.05)}
.rail-btn.active{color:#fff;border-left-color:var(--gold);background:rgba(216,35,42,.16)}

.studio-panel{flex:none;width:286px;border-right:1px solid var(--line);background:var(--bg-alt);overflow-y:auto;max-height:760px}
.panel{display:none;padding:22px}
.panel.active{display:block}
.panel h3{font-family:'Poppins',sans-serif;font-size:1.05rem;color:var(--ink);margin-bottom:14px}
.panel-note{color:var(--muted);font-size:.82rem;line-height:1.5;margin-top:12px}
.btn-block{width:100%;margin-top:10px}

.studio-panel textarea{width:100%;padding:12px;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:.95rem;resize:vertical;background:#fff}
.studio-panel select{width:100%;padding:11px;border:1px solid var(--line);border-radius:10px;font-family:inherit;background:#fff;margin-bottom:12px}
.text-tools{margin-top:20px;border-top:1px solid var(--line);padding-top:18px}
.text-tools label{display:block;font-weight:500;color:var(--ink);font-size:.86rem;margin:10px 0 6px}
.text-tools input[type=range]{width:100%;accent-color:var(--gold)}
.color-row{display:flex;align-items:center;gap:10px}
input[type=color]{width:46px;height:36px;border:1px solid var(--line);border-radius:8px;background:#fff;cursor:pointer;padding:2px}
.quick-colors{display:flex;gap:6px;flex-wrap:wrap}
.qc{width:22px;height:22px;border-radius:50%;border:1px solid var(--line);cursor:pointer;padding:0}
.qc:hover{transform:scale(1.12)}
.style-btns{display:flex;gap:6px;margin-top:14px;flex-wrap:wrap}
.style-btns button{width:38px;height:36px;border:1px solid var(--line);background:#fff;border-radius:8px;cursor:pointer;font-size:1rem;color:var(--ink)}
.style-btns button:hover,.style-btns button.on{background:var(--navy);color:#fff;border-color:var(--navy)}

.art-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.art-item{aspect-ratio:1;border:1px solid var(--line);background:#fff;border-radius:10px;cursor:pointer;padding:12px;transition:.2s}
.art-item:hover{border-color:var(--gold);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.art-item svg{width:100%;height:100%}

.studio-main{flex:1;display:flex;flex-direction:column;align-items:center;padding:18px;background:
    radial-gradient(circle at 50% 30%,#fff,var(--bg-alt))}
.studio-toolbar{display:flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--line);border-radius:50px;padding:6px 10px;box-shadow:var(--shadow-sm);margin-bottom:14px}
.studio-toolbar button{width:38px;height:38px;border:none;background:none;border-radius:50%;cursor:pointer;font-size:1rem;color:var(--ink);display:flex;align-items:center;justify-content:center;transition:.2s}
.studio-toolbar button:hover:not(:disabled){background:var(--bg-alt)}
.studio-toolbar button:disabled{opacity:.32;cursor:default}
.studio-toolbar button.danger:hover:not(:disabled){background:#fdecec;color:var(--gold-deep)}
.tb-sep{width:1px;height:24px;background:var(--line);margin:0 4px}

.stage-wrap{flex:1;display:flex;align-items:center;justify-content:center}
.stage{position:relative}
.stage #ss-shirt{position:absolute;inset:0;z-index:1;border-radius:6px}
.print-guide{position:absolute;z-index:4;border:1.5px dashed rgba(216,35,42,.55);border-radius:4px;pointer-events:none}

.studio-views{flex:none;width:118px;border-left:1px solid var(--line);background:var(--bg-alt);padding:16px 12px;display:flex;flex-direction:column;gap:12px}
.view-btn{background:#fff;border:2px solid var(--line);border-radius:12px;cursor:pointer;padding:8px 6px;display:flex;flex-direction:column;align-items:center;gap:4px;transition:.2s}
.view-btn:hover{border-color:var(--gold)}
.view-btn.active{border-color:var(--navy);box-shadow:var(--shadow-sm)}
.view-btn small{font-size:.78rem;color:var(--ink);font-weight:500}
.view-thumb{position:relative;width:100%;height:74px;display:block;overflow:hidden;border-radius:8px;background:#fff}
.view-thumb img{width:100%;height:100%;object-fit:cover;object-position:center 22%}
.view-icon{width:100%;height:54px;display:flex;align-items:center;justify-content:center;color:var(--navy)}
.view-icon svg{width:30px;height:30px}

.studio-bottom{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
    padding:16px 26px;background:#fff;border-bottom:1px solid var(--line);box-shadow:0 -6px 20px -16px rgba(14,27,51,.4)}
.sb-product{display:flex;align-items:center;gap:14px}
.sb-chip{width:42px;height:42px;border-radius:8px;border:1px solid var(--line);flex:none}
.sb-product b{display:block;color:var(--ink);font-size:.96rem}
.sb-product small{color:var(--muted);font-size:.85rem}
.sb-product a{color:var(--gold-deep);font-weight:600}
.sb-actions{display:flex;gap:12px}

.ss-lightbox{position:fixed;inset:0;background:rgba(14,27,51,.82);z-index:100;display:flex;align-items:center;justify-content:center;padding:30px}
.ss-lightbox[hidden]{display:none}
.ss-lightbox-inner{position:relative;background:#fff;border-radius:14px;padding:20px;max-width:90vw;max-height:90vh}
.ss-lightbox-inner img{max-width:78vw;max-height:80vh;display:block}
.ss-lightbox-close{position:absolute;top:-14px;right:-14px;width:38px;height:38px;border-radius:50%;border:none;background:var(--gold);color:#fff;font-size:1.4rem;cursor:pointer;box-shadow:var(--shadow-sm)}

@media(max-width:1080px){
    .studio{flex-wrap:wrap}
    .studio-main{order:5;width:100%;flex:1 1 100%}
    .studio-views{order:4;width:100%;flex-direction:row;justify-content:center;border-left:none;border-top:1px solid var(--line)}
    .view-thumb{width:54px;height:54px}
    .studio-panel{flex:1 1 auto;max-height:none}
}
@media(max-width:620px){
    .studio-rail{width:100%;flex-direction:row;justify-content:space-around;padding:4px}
    .rail-btn{border-left:none;border-bottom:3px solid transparent;flex:1}
    .rail-btn.active{border-left-color:transparent;border-bottom-color:var(--gold)}
    .studio-panel{flex:1 1 100%}
}

/* ---------- Mockup tool ---------- */
.mockup-wrap{display:grid;grid-template-columns:1.15fr .85fr;gap:38px;align-items:start}
.shirt-stage{background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--radius);padding:18px;position:relative}
.shirt-stage svg{width:100%;height:auto;display:block;touch-action:none;user-select:none}
.mock-panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm)}
.mock-panel h3{font-family:'Poppins',sans-serif;font-size:1rem;color:var(--ink);margin:22px 0 12px}
.mock-panel h3:first-child{margin-top:0}

.upload-drop{display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center;
    border:2px dashed var(--line);border-radius:var(--radius-sm);padding:24px;cursor:pointer;color:var(--gold-deep);transition:.2s}
.upload-drop:hover{border-color:var(--gold);background:rgba(216,35,42,.04)}
.upload-drop b{color:var(--ink);font-weight:600;margin-top:6px}
.upload-drop span{color:var(--muted);font-size:.85rem}
.upload-drop em{color:var(--gold-deep);font-style:normal;font-size:.85rem;font-weight:600}

.swatches{display:flex;gap:12px;flex-wrap:wrap}
.swatch{width:42px;height:42px;border-radius:50%;border:2px solid var(--line);cursor:pointer;padding:0;transition:.2s}
.swatch:hover{transform:scale(1.08)}
.swatch.active{outline:3px solid var(--gold);outline-offset:2px}

.preset-row{display:flex;gap:8px;flex-wrap:wrap}
.preset-row .pf-tab{padding:9px 16px;font-size:.9rem}

.slider-row{margin-top:20px}
.slider-row label{display:block;font-weight:500;color:var(--ink);margin-bottom:8px;font-size:.92rem}
.slider-row input[type=range]{width:100%;accent-color:var(--gold)}

.check-row{display:flex;align-items:center;gap:9px;margin-top:18px;color:var(--ink);font-size:.92rem;cursor:pointer}
.check-row input{accent-color:var(--gold);width:17px;height:17px}

.mock-actions{display:flex;gap:12px;margin-top:24px}
.mock-actions .btn{flex:1;text-align:center}
.btn-outline-dark{background:transparent;border:2px solid var(--navy);color:var(--navy)}
.btn-outline-dark:hover{background:var(--navy);color:#fff}

.mock-note{margin-top:18px;color:var(--muted);font-size:.85rem;line-height:1.5}

@media(max-width:880px){.mockup-wrap{grid-template-columns:1fr}.shirt-stage{max-width:480px;margin:0 auto}}

/* ---------- Newsletter ---------- */
.newsletter{background:var(--navy-2);color:#fff;padding:54px 0}
.newsletter-inner{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.newsletter h3{color:#fff;font-size:1.6rem}
.newsletter p{color:#aebbd6}
.newsletter-form{display:flex;gap:10px}
.newsletter-form input{padding:13px 16px;border-radius:50px;border:none;min-width:280px;font-family:inherit}
.newsletter-form input:focus{outline:2px solid var(--gold)}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy);color:#cdd6e8}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.3fr;gap:34px;padding:64px 0 40px}
.footer-tag{color:var(--gold);font-weight:500;margin:10px 0 8px}
.footer-muted{color:#8ea0c4;font-size:.92rem}
.footer-col h4{color:#fff;font-family:'Poppins',sans-serif;font-size:1.05rem;margin-bottom:16px}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:10px}
.footer-col a{color:#aebbd6;font-size:.93rem}
.footer-col a:hover{color:var(--gold-soft)}
.footer-contact li{color:#aebbd6;font-size:.93rem}
.social-link{display:inline-flex;margin-top:14px;width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.08);color:#fff;align-items:center;justify-content:center}
.social-link:hover{background:var(--gold);color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.09)}
.footer-bottom-inner{display:flex;justify-content:space-between;align-items:center;padding:20px 0;flex-wrap:wrap;gap:10px}
.footer-bottom p{color:#8ea0c4;font-size:.88rem}
.footer-bottom ul{list-style:none;display:flex;gap:20px}
.footer-bottom a{color:#aebbd6;font-size:.88rem}
.footer-bottom a:hover{color:var(--gold-soft)}

/* ---------- Back to top ---------- */
.back-to-top{position:fixed;right:22px;bottom:22px;width:46px;height:46px;border-radius:50%;background:var(--gold);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.3rem;font-weight:700;box-shadow:var(--shadow-sm);opacity:0;visibility:hidden;transform:translateY(10px);transition:.3s;z-index:40}
.back-to-top.show{opacity:1;visibility:visible;transform:translateY(0)}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:.6s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:980px){
    .hero-inner,.about-grid,.form-wrap{grid-template-columns:1fr}
    .hero-visual{order:-1;max-width:380px}
    .services-grid,.stats-grid{grid-template-columns:repeat(2,1fr)}
    .why-grid,.tst-grid,.pf-grid{grid-template-columns:repeat(2,1fr)}
    .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
    section{padding:64px 0}
    .hero h1{font-size:2.4rem}
    .nav-toggle{display:flex}
    .main-nav{position:fixed;inset:74px 0 auto 0;background:#fff;border-bottom:1px solid var(--line);transform:translateY(-130%);transition:.35s;box-shadow:var(--shadow)}
    .main-nav.open{transform:none}
    .main-nav ul{flex-direction:column;align-items:stretch;padding:14px;gap:2px}
    .main-nav a{padding:14px 16px}
    .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;padding-left:14px}
    .nav-toggle.active span:nth-child(1){transform:translateY(8px) rotate(45deg)}
    .nav-toggle.active span:nth-child(2){opacity:0}
    .nav-toggle.active span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
}
@media(max-width:520px){
    .services-grid,.stats-grid,.why-grid,.tst-grid,.pf-grid,.footer-grid,.form-grid-2{grid-template-columns:1fr}
    .newsletter-form{width:100%;flex-direction:column}
    .newsletter-form input{min-width:0;width:100%}
}
