@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;0,700;1,300;1,400;1,600&family=DM+Sans:wght@300;400;500&display=swap');

/* === RESET & BASE === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --cream:hsl(38,50%,94%);--cream-dark:hsl(36,36%,89%);--cream-mid:hsl(35,31%,84%);
  --crimson:hsl(352,78%,40%);--crimson-dark:hsl(352,81%,30%);
  --ink:hsl(30,14%,10%);--mid:hsl(24,9%,38%);--border-c:hsl(30,14%,88%);
  --radius:0.25rem;
}
html{scroll-behavior:smooth;background:var(--ink);scroll-padding-top:5.5rem}
body{font-family:'DM Sans',sans-serif;font-weight:300;background:var(--cream);color:var(--ink);overflow-x:hidden;line-height:1.65;min-width:320px;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit}
ul{list-style:none}
p,h1,h2,h3,li,.work-tag,.work-role,.sh-title,.sh-sub,.cl-value{overflow-wrap:break-word}
.font-serif,h1,h2,h3,.sh-num,.sh-title,.hero-heading,.about-statement,.contact-heading,.impact-number,.skill-name,.timeline-title,.nav-logo{font-family:'Cormorant Garamond',serif}
.text-crimson, em {color:var(--crimson)}
.italic, em {font-style:italic}
.bg-cream-dark{background:var(--cream-dark)}
.bg-ink{background:var(--ink)}
.text-white{color:#fff}

/* === NAV === */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.2rem 1.5rem;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);background:hsl(38,50%,94%,0.95);border-bottom:1px solid hsl(30,14%,10%,0.1);transition:padding .3s,box-shadow .3s}
.nav.shrunk{padding-top:.75rem;padding-bottom:.75rem}
.nav.shrunk{box-shadow:0 12px 32px rgba(30,25,22,.06)}
@media(min-width:768px){.nav{padding:1.4rem 5rem}.nav.shrunk{padding:.9rem 5rem}}
.nav-logo{font-size:1.25rem;font-weight:600;letter-spacing:.03em;text-decoration:none;white-space:nowrap}
.nav-links{display:none;gap:2.5rem}
@media(min-width:768px){.nav-links{display:flex}}
.nav-link{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--mid);text-decoration:none;transition:color .2s;white-space:nowrap}
.nav-link:hover{color:var(--crimson)}
.nav-cta{display:inline-block;padding:.55rem 1.4rem;border:1px solid var(--crimson);color:var(--crimson);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;text-decoration:none;transition:all .25s}
.nav-cta:hover{background:var(--crimson);color:#fff}

/* === HERO === */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;padding:0 1.5rem 5rem;position:relative;overflow:hidden}
@media(min-width:768px){.hero{padding:0 5rem 6rem}}
.hero-line{position:absolute;top:0;left:1.5rem;right:1.5rem;height:1px;background:hsl(30,14%,10%,0.1)}
@media(min-width:768px){.hero-line{left:5rem;right:5rem}}
.hero-watermark{position:absolute;top:50%;right:-3vw;transform:translateY(-58%);font-family:'Cormorant Garamond',serif;font-weight:700;font-size:28vw;color:hsl(352,78%,40%,0.035);line-height:1;pointer-events:none;user-select:none;white-space:nowrap}
.hero-eyebrow{font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:var(--crimson);margin-bottom:2rem}
.hero-heading{font-weight:300;line-height:.88;letter-spacing:0;margin-bottom:2.5rem;font-size:clamp(3.25rem,18vw,7rem)}
@media(min-width:961px){.hero-heading{font-size:clamp(5rem,11vw,10.5rem)}}
.hero-bottom{display:flex;flex-direction:column;gap:2.5rem}
@media(min-width:768px){.hero-bottom{flex-direction:row;justify-content:space-between;align-items:flex-end;gap:4rem}}
.hero-desc{max-width:34rem;font-size:1rem;line-height:1.78;color:var(--mid)}
.hero-actions{display:flex;flex-direction:column;gap:1.35rem;width:100%}
@media(min-width:768px){.hero-actions{align-items:flex-end}}
.hero-btns{display:flex;flex-wrap:wrap;gap:.75rem;width:100%}
@media(min-width:768px){.hero-btns{justify-content:flex-end;width:auto}}
.btn-primary,.btn-ghost,.btn-outline{display:inline-flex;align-items:center;justify-content:center;min-height:2.75rem;min-width:8.85rem;padding:.75rem 2rem;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;text-decoration:none;transition:all .3s;text-align:center;line-height:1.1;white-space:nowrap}
.btn-primary{background:var(--crimson);color:#fff;border:1px solid var(--crimson)}
.btn-primary:hover{background:var(--crimson-dark);transform:translateY(-2px)}
.btn-ghost{border:1px solid var(--ink);color:var(--ink)}
.btn-ghost:hover{border-color:var(--crimson);color:var(--crimson)}
.btn-outline{border:1px solid var(--mid);color:var(--mid)}
.btn-outline:hover{border-color:var(--ink);color:var(--ink)}
.btn-outline.disabled{opacity:.55;cursor:not-allowed;pointer-events:none}
.btn-outline.disabled:hover{border-color:var(--mid);color:var(--mid);transform:none}
.hero-location{font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;color:var(--mid);line-height:1.6;white-space:pre-line}
@media(min-width:768px){.hero-location{text-align:right}}
.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:none;flex-direction:column;align-items:center;gap:.5rem}
@media(min-width:768px){.hero-scroll{display:flex}}
.scroll-line{width:1px;height:2.75rem;background:var(--crimson);animation:scrollPulse 2.2s ease infinite}
.scroll-text{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mid)}
.scroll-text em{font-family:'Cormorant Garamond',serif;font-size:.78rem;letter-spacing:.12em;color:var(--mid)}

/* === IMPACT === */
#impact { background: var(--ink); padding: 5rem 1.25rem; overflow:hidden; }
@media(min-width:768px){ #impact { padding: 6rem 5rem; } }
.impact-intro { font-size: .75rem; letter-spacing: .18em; text-transform: uppercase; color: rgba(255,255,255,.62); margin-bottom: 3rem; text-align: center; font-weight:400; }
@media(min-width:768px){ .impact-intro { margin-bottom: 3.5rem; } }
.impact-grid { display: grid; grid-template-columns: 1fr; gap: 1px; background: rgba(255,255,255,0.07); }
@media(min-width:560px){ .impact-grid { grid-template-columns: repeat(2,1fr); } }
@media(min-width:960px){ .impact-grid { grid-template-columns: repeat(4,1fr); background: transparent; } }
.impact-item { padding: 2.25rem 1rem; text-align: center; transition: background .3s,border-color .3s; background: var(--ink); min-width:0; position:relative; }
.impact-item::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--crimson);opacity:.95}
@media(min-width:768px){ .impact-item { padding: 2.5rem 1.5rem; } }
@media(min-width:960px){ .impact-item { border-right: 1px solid rgba(255,255,255,0.07); } }
@media(min-width:1200px){ .impact-item { padding: 2.5rem 2rem; } }
@media(min-width:960px){ .impact-item:last-child { border-right: none; } }
.impact-item:hover { background: rgba(255,255,255,.03); }
.impact-number { font-family: 'Cormorant Garamond', serif; font-weight: 300; font-size: clamp(3.5rem,18vw,5.5rem); line-height: .95; margin-bottom: .9rem; color: #fff; letter-spacing: 0; font-variant-numeric: tabular-nums; min-height: 1em; overflow-wrap:anywhere; text-wrap:balance; }
@media(min-width:960px){ .impact-number { font-size: 4.85rem; } }
.impact-number .accent { color: #ff6f82; margin-left: 0.1rem; }
.impact-label { max-width:18rem;margin:0 auto;font-size: .85rem; letter-spacing: .12em; text-transform: uppercase; color: rgba(255,255,255,0.9); line-height: 1.55; font-weight:400; }
.impact-source { font-size: .68rem; color: rgba(255,255,255,.48); margin-top: .55rem; font-style: italic; line-height:1.5; }
#impact .reveal{opacity:1;transform:none;transition:background .3s}

/* === SECTIONS === */
.section{padding:7rem 1.5rem}
@media(min-width:768px){.section{padding:7rem 5rem}}
.section-header{display:flex;align-items:baseline;gap:1rem 1.5rem;margin-bottom:4rem;padding-bottom:1.5rem;border-bottom:1px solid hsl(30,14%,10%,0.1);flex-wrap:wrap}
@media(min-width:961px){.section-header{margin-bottom:5rem}}
.section-header.dark{border-color:rgba(255,255,255,.1)}
.sh-num{font-family:'Cormorant Garamond',serif;font-size:.95rem;font-style:italic;color:var(--crimson);margin-right:.5rem}
.section-header.dark .sh-num{color:var(--crimson)}
.sh-title{font-family:'Cormorant Garamond',serif;font-weight:400;letter-spacing:0;font-size:2rem;text-transform: capitalize;line-height:1.15;max-width:48rem;text-wrap:balance}
@media(min-width:768px){.sh-title{font-size:2.6rem}}
.section-header.dark .sh-title{color:#fff}
.sh-sub{margin-left:auto;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--mid);font-weight:400;display:none;line-height:1.5;text-align:right;max-width:24rem}
@media(min-width:768px){.sh-sub{display:block}}
.section-header.dark .sh-sub{color:rgba(255,255,255,.4)}

/* === ABOUT === */
.about-grid{display:grid;gap:3.5rem}
@media(min-width:768px){.about-grid{grid-template-columns:1.1fr .9fr}}
@media(min-width:961px){.about-grid{gap:7rem}}
.about-statement{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:1.6rem;line-height:1.5;letter-spacing:0;margin-bottom:2.5rem;max-width:48rem;text-wrap:pretty}
@media(min-width:768px){.about-statement{font-size:2.15rem;line-height:1.55}}
.about-statement em{font-style:italic;color:var(--crimson)}
.about-body{font-size:.95rem;line-height:1.85;color:var(--mid);white-space:pre-line;max-width:45rem}
.about-details{display:flex;flex-direction:column;gap:1.75rem}
.about-detail{padding-left:1.25rem;border-left:2px solid var(--crimson)}
.about-detail-label{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--crimson);margin-bottom:.375rem}
.about-detail-value{font-size:.9rem;line-height:1.6}

/* === WORK CARDS === */
.work-grid{display:grid;gap:2px}
@media(min-width:768px){.work-grid{grid-template-columns:repeat(2,1fr)}}
.work-card{position:relative;overflow:hidden;padding:2.5rem;background:#fff;transition:transform .4s ease,box-shadow .4s ease;min-width:0}
@media(min-width:961px){.work-card{padding:2.8rem}}
.work-card::after{content:"";position:absolute;left:2.5rem;right:2.5rem;bottom:1.5rem;height:1px;background:rgba(30,25,22,.12);transform:scaleX(0);transform-origin:left;transition:transform .4s ease}
.work-card:hover::after{transform:scaleX(1)}
.work-card:hover{transform:translateY(-5px);box-shadow:0 24px 48px rgba(0,0,0,.09)}
.work-card.featured{grid-column:1/-1;display:grid;gap:3.5rem;padding:3.5rem;background:var(--ink);color:#fff}
@media(min-width:768px){.work-card.featured{grid-template-columns:1.15fr 1fr}}
.work-card.featured::after{background:rgba(255,255,255,.15)}
.work-card.on-dark{padding:2.5rem;background:rgba(255,255,255,.04);color:#fff}
.work-card.on-dark::after{background:rgba(255,255,255,.2)}
@media(min-width:961px){.work-card.featured{gap:4rem;padding:4rem}}
.work-tag{font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--crimson);margin-bottom:1.75rem;font-weight: 500;line-height:1.55;max-width:42rem}
.work-tag.light{color:#F8B0B8}
.work-img-wrap{width:100%;height:14rem;overflow:hidden;margin-bottom:1.75rem}
.work-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.work-img-wrap:hover img{transform:scale(1.05)}
.work-img-placeholder{width:100%;height:14rem;overflow:hidden;margin-bottom:1.75rem;display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1rem;color:rgba(255,255,255,.6);text-align:center;padding:1.5rem}
.work-title{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:1.5rem;line-height:1.2;margin-bottom:.7rem;max-width:48rem;text-wrap:balance}
@media(min-width:768px){.work-title{font-size:1.65rem}}
.work-role{font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--mid);margin-bottom:1rem;line-height:1.55}
.work-role.light{color:rgba(255,255,255,.45)}
.work-desc{font-size:.92rem;line-height:1.78;color:var(--mid);margin-bottom:1.75rem;max-width:64rem}
.work-desc.light{color:rgba(255,255,255,.65)}
.work-links{display:flex;flex-wrap:wrap;gap:.625rem;margin-bottom:1.25rem}
.work-link{display:inline-flex;align-items:center;font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;color:var(--crimson);border-bottom:1px solid hsl(352,78%,40%,0.3);padding-bottom:2px;transition:border-color .2s}
.work-link:hover{border-color:var(--crimson)}
.work-link.light{color:#E8A0A8;border-color:rgba(232,160,168,.3)}
.work-link.light:hover{border-color:#E8A0A8}
.work-pills{display:flex;flex-wrap:wrap;gap:.5rem}
.work-pill{display:inline-block;padding:.32rem .75rem;font-size:.7rem;line-height:1.25;border:1px solid hsl(30,14%,10%,0.1);border-radius:999px;background:var(--cream);color:var(--ink)}
.work-pill.hi{background:var(--crimson);border-color:var(--crimson);color:#fff}
.work-pill.dark{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.15);color:#fff}
.work-featured-img{overflow:hidden;min-height:280px}
.work-featured-img img{width:100%;height:100%;object-fit:cover}
.work-featured-placeholder{overflow:hidden;min-height:280px;display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-style:italic;color:rgba(255,255,255,.6);padding:1.5rem;text-align:center}

/* === SKILLS === */
.skills-grid{display:grid;gap:2px}
@media(min-width:640px){.skills-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:768px){.skills-grid{grid-template-columns:repeat(3,1fr)}}
.skill-card{background:#fff;padding:2.25rem;border-top:3px solid transparent;transition:border-color .2s;min-width:0}
.skill-card:hover{border-top-color:var(--crimson)}
.skill-icon{font-size:1.5rem;margin-bottom:.75rem}
.skill-name{font-family:'Cormorant Garamond',serif;font-size:1.32rem;line-height:1.15;margin-bottom:.65rem;text-wrap:balance}
.skill-detail{font-size:.9rem;color:var(--mid);line-height:1.65}
.skill-tools{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid hsl(30,14%,10%,0.08)}
.skill-tool{display:inline-flex;align-items:center;min-height:2rem;font-size:.75rem;line-height:1.2;padding:.4rem 1rem;background:var(--cream-dark);border:1px solid var(--border-c);border-radius:9999px;color:var(--ink);font-weight:500;letter-spacing:.02em;transition:background 0.3s, color 0.3s, border-color 0.3s}
.skill-tool:hover{background:var(--crimson);color:#fff;border-color:var(--crimson)}

/* === TIMELINE === */
.timeline{position:relative;padding-left:1.5rem}
.timeline-line{position:absolute;left:0;top:.5rem;bottom:0;width:1px;background:hsl(30,14%,10%,0.1)}
.timeline-item{position:relative;padding-left:3.5rem;padding-bottom:4rem}
.timeline-item:last-child{padding-bottom:0}
.timeline-dot{position:absolute;left:-.3125rem;top:.5rem;width:.625rem;height:.625rem;border-radius:50%;background:var(--crimson)}
.timeline-date{font-size:.67rem;letter-spacing:.18em;text-transform:uppercase;color:var(--crimson);margin-bottom:.5rem}
.timeline-title{font-family:'Cormorant Garamond',serif;font-size:1.5rem;line-height:1.18;margin-bottom:.35rem;text-wrap:balance}
.timeline-org{font-size:.875rem;color:var(--mid);margin-bottom:1.25rem}
.timeline-points{display:flex;flex-direction:column;gap:.5rem}
.timeline-points li{font-size:.9rem;line-height:1.7;color:var(--mid);padding-left:1.25rem;position:relative;max-width:58rem}
.timeline-points .dash{position:absolute;left:0;color:var(--crimson)}

.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.2s; }
.reveal-delay-3 { transition-delay: 0.3s; }

/* === CONTACT & FOOTER === */
#contact {
    background: var(--ink);
    color: #fff;
    padding: 10rem 1.5rem 8rem;
    text-align: center;
    position: relative;
    overflow: hidden;
}
@media(min-width:768px){ #contact { padding: 9rem 5rem 6rem; } }

.contact-bg {
    position: absolute;
    bottom: -5rem;
    left: 50%;
    transform: translateX(-50%);
    font-family: 'Cormorant Garamond', serif;
    font-weight: 700;
    font-size: 20vw;
    color: rgba(255,255,255,0.02);
    line-height: 1;
    white-space: nowrap;
    pointer-events: none;
    user-select: none;
}

.contact-eyebrow {
    font-size: 0.65rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.35);
    margin-bottom: 1.5rem;
}

.contact-heading {
    font-family: 'Cormorant Garamond', serif;
    font-weight: 300;
    line-height: 1.15;
    margin: 0 auto 3.5rem auto;
    font-size: clamp(2.5rem, 6vw, 5rem);
    position: relative;
    z-index: 2;
    text-wrap:balance;
    max-width: 48rem;
}
.contact-heading em {
    font-style: italic;
    color: #E8A0A8; /* Pink/Crimson accent */
}

.contact-links {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 2rem;
    margin-bottom: 3rem;
    position: relative;
    z-index: 2;
}
@media(min-width:768px){ .contact-links { flex-direction: row; flex-wrap:wrap; gap: 4rem; } }

.contact-link {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    text-decoration: none;
    color: #fff;
    transition: opacity 0.2s;
}
.cl-label {
    font-size: 0.6rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.3);
}
.cl-value{font-size:1rem;color:#fff;text-decoration:none;line-height:1.4}
.cv-download-wrap{position:relative;z-index:2}

.contact-cv-btn{display:inline-block;padding:.85rem 2.5rem;border:1px solid rgba(255,255,255,0.2);color:rgba(255,255,255,0.8);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;text-decoration:none;transition:all .3s}
.contact-cv-btn:hover{border-color:#fff;color:#fff;background:rgba(255,255,255,0.05)}

.site-footer{background:var(--ink);border-top:1px solid rgba(255,255,255,0.05);padding:1.5rem 1.5rem calc(1.5rem + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:.8rem;text-align:center;justify-content:space-between;align-items:center;color:rgba(255,255,255,0.36);font-size:.72rem;position:relative;z-index:2;width:100%;box-shadow:0 0 0 100vmax var(--ink);clip-path:inset(0 -100vmax)}
@media(min-width:960px){.site-footer{flex-direction:row;padding:1.8rem 5rem;text-align:left}}
.footer-center{font-size:.6rem;letter-spacing:.05em;opacity:.8}
.footer-right{display:inline-flex;align-items:center;justify-content:center;gap:.75rem}
.footer-social-link{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:1px solid rgba(255,255,255,.12);border-radius:999px;color:rgba(255,255,255,.62);text-decoration:none;transition:color .2s,border-color .2s,background .2s,transform .2s}
.footer-social-link:hover{color:#fff;border-color:rgba(255,255,255,.36);background:rgba(255,255,255,.06);transform:translateY(-1px)}
.back-to-top{position:fixed;right:1rem;bottom:1rem;z-index:80;width:2.75rem;height:2.75rem;border:1px solid rgba(181,30,55,.28);border-radius:999px;background:hsl(38,50%,94%,0.92);color:var(--crimson);box-shadow:0 16px 36px rgba(30,25,22,.14);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);cursor:pointer;opacity:0;pointer-events:none;transform:translateY(.75rem);transition:opacity .25s,transform .25s,background .2s,color .2s}
.back-to-top.visible{opacity:1;pointer-events:auto;transform:translateY(0)}
.back-to-top:hover{background:var(--crimson);color:#fff}
.back-to-top span{font-size:1rem;line-height:1}
@media(min-width:768px){.back-to-top{right:1.5rem;bottom:1.5rem}}

/* === ADMIN TOOLBAR === */
.admin-toolbar{position:fixed;bottom:.75rem;left:50%;transform:translateX(-50%);z-index:100;display:flex;align-items:center;gap:.5rem;background:var(--ink);color:#fff;padding:.5rem .75rem;border-radius:9999px;box-shadow:0 25px 50px rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.1)}
.toolbar-label{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;padding:0 .5rem;color:rgba(255,255,255,.6);display:none}
@media(min-width:640px){.toolbar-label{display:inline}}
.toolbar-btn{padding:.375rem 1rem;background:var(--crimson);color:#fff;border-radius:9999px;font-size:.72rem;text-decoration:none;transition:background .2s;white-space:nowrap}
.toolbar-btn:hover{background:var(--crimson-dark)}
.toolbar-btn-ghost{padding:.375rem 1rem;color:rgba(255,255,255,.6);font-size:.72rem;text-decoration:none;border-radius:9999px;transition:all .2s;white-space:nowrap}
.toolbar-btn-ghost:hover{color:#fff;background:rgba(255,255,255,.1)}

/* === ANIMATIONS === */
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes scrollPulse{0%,100%{opacity:1;transform:scaleY(1)}50%{opacity:.3;transform:scaleY(.4)}}
.anim-fade-up{opacity:0;animation:fadeUp .9s ease forwards}
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* === ADMIN PAGES === */
.admin-layout{min-height:100vh;display:flex;flex-direction:column;background:var(--cream);color:var(--ink)}
.admin-header{background:#fff;padding:1.25rem 1.25rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(0,0,0,0.05)}
@media(min-width:768px){.admin-header{padding:1.5rem 3rem}}
@media(min-width:1200px){.admin-header{padding:1.5rem 5rem}}
.admin-header h1{font-family:'Cormorant Garamond',serif;font-size:1.35rem;font-weight:600}
@media(min-width:768px){.admin-header h1{font-size:1.5rem}}

.admin-nav-bar{background:#f0e9e1;padding:0 .5rem;display:flex;overflow-x:auto;scrollbar-width:none;border-bottom:1px solid rgba(0,0,0,0.03);-webkit-overflow-scrolling:touch}
@media(min-width:1180px){.admin-nav-bar{justify-content:center;padding:0 2rem}}
.admin-nav-bar::-webkit-scrollbar{display:none}
.admin-nav-item{padding:1rem .75rem;font-size:.6rem;text-transform:uppercase;letter-spacing:.08em;color:rgba(0,0,0,0.4);text-decoration:none;white-space:nowrap;transition:all .2s;cursor:pointer;font-weight:600;border-bottom:3px solid transparent;flex-shrink:0}
@media(min-width:768px){.admin-nav-item{padding:1.25rem 1.25rem;font-size:.68rem;letter-spacing:.1em}}
@media(min-width:1200px){.admin-nav-item{padding:1.5rem 1.75rem;font-size:.72rem;letter-spacing:.13em}}
.admin-nav-item:hover{color:var(--ink)}
.admin-nav-item.active{color:var(--ink);border-bottom-color:var(--crimson);background:rgba(255,255,255,0.4)}

.admin-main{flex:1;padding:1.5rem 1rem;display:flex;flex-direction:column;align-items:center}
@media(min-width:768px){.admin-main{padding:3rem 2rem}}
@media(min-width:1200px){.admin-main{padding:4rem 5rem}}
.cms-builder-shell{width:100%;max-width:960px;display:grid;grid-template-columns:minmax(0,1fr);gap:1.5rem;align-items:start}
.cms-editor{min-width:0}
.admin-card{background:#fff;padding:1.5rem;width:100%;max-width:900px;margin:0 auto;border-radius:4px;box-shadow:0 15px 50px rgba(0,0,0,0.03);border:1px solid rgba(0,0,0,0.02)}
@media(min-width:768px){.admin-card{padding:3rem}}
@media(min-width:1200px){.admin-card{padding:4rem}}
.admin-card-title{font-family:'Cormorant Garamond',serif;font-size:1.5rem;margin-bottom:1.75rem;color:var(--ink);font-weight:500;text-align:center}
@media(min-width:768px){.admin-card-title{font-size:2rem;margin-bottom:2.5rem}}
.admin-panel{display:none;width:100%;max-width:900px}
.admin-panel.active{display:block;animation:fadeUp .4s cubic-bezier(0.16, 1, 0.3, 1)}
.admin-loading{text-align:center;padding:3rem 1rem;color:var(--mid);font-size:.85rem;letter-spacing:.05em}

.form-group{margin-bottom:1.25rem}
@media(min-width:768px){.form-group{margin-bottom:2rem}}
.form-group label{display:block;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--mid);margin-bottom:.5rem}
@media(min-width:768px){.form-group label{font-size:.72rem;margin-bottom:.75rem}}
.form-input,.form-textarea{width:100%;padding:.75rem .85rem;border:1px solid #eee;font-family:inherit;font-size:.875rem;outline:none;border-radius:2px;background:#fcfaf7;transition:all .2s}
@media(min-width:768px){.form-input,.form-textarea{padding:1rem 1.25rem;font-size:.95rem}}
.form-input:focus,.form-textarea:focus{border-color:var(--crimson);background:#fff;box-shadow:0 0 0 4px rgba(181,30,55,0.03)}
.form-row{display:grid;grid-template-columns:1fr;gap:.75rem}
@media(min-width:640px){.form-row{grid-template-columns:1fr 1fr;gap:1.5rem}}
.upload-row{display:grid;grid-template-columns:1fr;gap:.6rem;align-items:stretch}
@media(min-width:640px){.upload-row{grid-template-columns:minmax(0,1fr) auto;align-items:center}}
.upload-btn{margin:0;text-align:center;white-space:nowrap}
.upload-preview{margin-top:.75rem;min-height:0}
.upload-preview img{width:160px;height:96px;object-fit:cover;border:1px solid #eee;background:#f9f9f9;border-radius:4px}
.upload-file{display:inline-flex;max-width:100%;padding:.65rem .75rem;border:1px solid #eee;background:#fcfaf7;border-radius:4px;font-size:.8rem}
.upload-file a{color:var(--crimson);text-decoration:none;overflow-wrap:anywhere}

.form-btn{background:var(--crimson);color:#fff;border:none;padding:.7rem 1.25rem;font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;cursor:pointer;transition:all .2s;font-weight:600}
@media(min-width:768px){.form-btn{padding:.75rem 1.5rem;font-size:.7rem}}
.form-btn:hover{background:var(--crimson-dark)}
.form-btn-danger{background:#eee;color:#333;border:none;padding:.7rem 1rem;font-size:.65rem;text-transform:uppercase;cursor:pointer;transition:all .2s}
@media(min-width:768px){.form-btn-danger{padding:.75rem 1rem;font-size:.7rem}}
.form-btn-danger:hover{background:#f03e3e;color:#fff}
.form-btn-outline{background:transparent;border:1px solid #ddd;padding:.7rem 1.25rem;font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;cursor:pointer;color:var(--mid);transition:all .2s}
@media(min-width:768px){.form-btn-outline{padding:.75rem 1.5rem;font-size:.7rem}}
.form-btn-outline:hover{border-color:var(--crimson);color:var(--crimson)}

.item-card{background:#fcfcfb;border:1px solid rgba(0,0,0,0.04);padding:1.25rem;margin-bottom:1.25rem;border-radius:4px}
@media(min-width:768px){.item-card{padding:2rem;margin-bottom:2rem}}
.item-card summary{font-family:'Cormorant Garamond',serif;font-size:1.15rem;cursor:pointer;margin-bottom:1rem;color:var(--ink)}
@media(min-width:768px){.item-card summary{font-size:1.25rem}}
.item-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid rgba(0,0,0,0.04)}

.toast{position:fixed;bottom:2rem;right:1rem;left:1rem;padding:.85rem 1.5rem;background:var(--ink);color:#fff;font-size:.78rem;z-index:1000;box-shadow:0 10px 30px rgba(0,0,0,0.15);border-radius:4px;text-align:center}
@media(min-width:640px){.toast{left:auto;right:2rem;max-width:360px;text-align:left;padding:1rem 2rem}}

/* === LOGIN === */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--cream);padding:1.5rem}
.login-card{width:100%;max-width:28rem;background:#fff;padding:2rem;border:1px solid hsl(30,14%,10%,0.1)}
@media(min-width:768px){.login-card{padding:2.5rem}}
.login-card h1{font-family:'Cormorant Garamond',serif;font-size:1.875rem;margin-bottom:.5rem;font-weight:400}
.login-card p{font-size:.875rem;color:var(--mid);margin-bottom:2rem}
.form-check{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}
.form-check input{width:1rem;height:1rem;accent-color:var(--crimson)}
.form-check label{font-size:.8rem}
