/* ===== DESIGN SYSTEM – PINK GU ===== */
:root {
    --primary: #d4617b;
    --primary-dark: #b8495f;
    --primary-soft: #fdf0f3;
    --primary-glow: rgba(212, 97, 123, 0.15);

    --ink: #1a1625;
    --muted: #6b6580;
    --surface: #ffffff;
    --surface-soft: #faf8fc;
    --surface-warm: #fef7f0;
    --line: #ede8f2;

    --accent-gold: #e8b84d;
    --accent-sage: #7db89e;
    --accent-lavender: #9b8ec4;

    --shadow-sm: 0 4px 12px rgba(26,22,37,.06);
    --shadow-md: 0 12px 32px rgba(26,22,37,.08);
    --shadow-lg: 0 24px 64px rgba(26,22,37,.12);
    --shadow-glow: 0 8px 32px rgba(212,97,123,.18);

    --radius: 12px;
    --radius-lg: 20px;
    --max-w: 1160px;
    --nav-h: 72px;
}

/* ===== RESET ===== */
*,*::before,*::after{box-sizing:border-box}
[hidden]{display:none!important}
html{scroll-behavior:smooth}
body{margin:0;font-family:"Poppins",Arial,sans-serif;color:var(--ink);background:var(--surface-soft);line-height:1.7;-webkit-font-smoothing:antialiased}
body.nav-open{overflow:hidden}
a{color:inherit;text-decoration:none}
img,svg{max-width:100%;display:block}
button,input,textarea,select{font:inherit}
h1,h2,h3,h4,p{margin-top:0}
h1,h2,h3{font-family:"Playfair Display",Georgia,serif;color:var(--ink)}
ul{list-style:none;margin:0;padding:0}

/* ===== HEADER ===== */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);border-bottom:1px solid var(--line);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}
.navbar{width:min(var(--max-w),calc(100% - 32px));min-height:var(--nav-h);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{font-family:"Playfair Display",Georgia,serif;font-size:1.5rem;font-weight:700;color:var(--primary-dark);transition:color .2s}
.brand:hover{color:var(--primary)}
.nav-links{display:flex;align-items:center;gap:6px;font-size:.88rem;font-weight:600}
.nav-links a{display:inline-flex;min-height:40px;align-items:center;padding:0 14px;border-radius:8px;color:var(--muted);transition:color .2s,background .2s}
.nav-links a:hover,.nav-links a.active{color:var(--primary-dark);background:var(--primary-soft)}

.menu-toggle{display:none;width:44px;height:44px;border:1px solid var(--line);border-radius:8px;background:var(--surface);cursor:pointer;position:relative}
.menu-toggle span{display:block;width:20px;height:2px;margin:5px auto;background:var(--primary-dark);transition:transform .25s,opacity .25s}
.menu-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle.open span:nth-child(2){opacity:0}
.menu-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== LAYOUT ===== */
.section{width:min(var(--max-w),calc(100% - 32px));margin:0 auto;padding:80px 0;scroll-margin-top:calc(var(--nav-h) + 12px)}
.section-heading{max-width:760px;margin-bottom:40px}
.eyebrow{margin:0 0 10px;color:var(--primary);font-size:.76rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}

h1{margin-bottom:20px;font-size:clamp(2.6rem,6vw,4.4rem);line-height:1.08}
h2{margin-bottom:14px;font-size:clamp(1.8rem,3.8vw,2.6rem);line-height:1.18}
h3{margin-bottom:10px;font-size:1.15rem;line-height:1.35}

/* ===== BUTTONS ===== */
.btn{min-height:48px;display:inline-flex;align-items:center;justify-content:center;padding:0 24px;border:1px solid transparent;border-radius:10px;font-weight:700;font-size:.9rem;cursor:pointer;transition:transform .2s,box-shadow .2s,background .2s,color .2s;text-align:center}
.btn:hover{transform:translateY(-2px)}
.btn.primary{background:var(--primary);color:#fff;box-shadow:var(--shadow-glow)}
.btn.primary:hover{background:var(--primary-dark)}
.btn.secondary{background:var(--surface);color:var(--primary-dark);border-color:var(--line);box-shadow:var(--shadow-sm)}
.btn.secondary:hover{border-color:var(--primary);color:var(--primary)}
.btn.ghost{background:var(--primary-soft);color:var(--primary-dark)}
.btn.ghost:hover{background:var(--primary);color:#fff}

/* ===== CARDS ===== */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:28px;transition:transform .3s,box-shadow .3s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}

.tag{display:inline-flex;min-height:26px;align-items:center;padding:0 10px;border-radius:6px;font-size:.75rem;font-weight:700}
.tag--pink{background:var(--primary-soft);color:var(--primary-dark)}
.tag--sage{background:#edf7f2;color:#4a8b6f}
.tag--lavender{background:#f0ecf8;color:#7b6dab}
.tag--gold{background:#fdf5e3;color:#b8891a}

/* ===== HERO (HOME) ===== */
.hero{min-height:calc(100vh - var(--nav-h));display:grid;grid-template-columns:1fr auto;align-items:center;gap:48px}
.hero-content{max-width:640px}
.hero-lead{color:var(--muted);font-size:1.05rem;max-width:560px}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}

.hero-portrait{width:300px;aspect-ratio:1;border-radius:50%;overflow:hidden;border:4px solid var(--primary-soft);box-shadow:0 0 0 8px var(--primary-glow),var(--shadow-lg);background:var(--primary-soft)}
.hero-portrait img{width:100%;height:100%;object-fit:cover}

.hero-intro-list{margin:18px 0 0;padding:0}
.hero-intro-list li{padding:4px 0;color:var(--muted);font-size:1rem}
.hero-intro-list li::before{content:"–";margin-right:10px;color:var(--primary);font-weight:700}

/* ===== BENTO GRID ===== */
.bento{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:auto auto;gap:16px}
.bento-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px;display:flex;flex-direction:column;justify-content:space-between;transition:transform .3s,box-shadow .3s;overflow:hidden;position:relative;cursor:pointer;text-decoration:none;color:inherit}
.bento-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}

.bento-card--profile{grid-column:1/2;grid-row:1/3;background:linear-gradient(135deg,var(--primary-soft),#fff5f7);border-color:rgba(212,97,123,.15)}
.bento-card--blog{grid-column:2/3;grid-row:1/2}
.bento-card--scent{grid-column:3/4;grid-row:1/2;background:var(--surface-warm);border-color:rgba(232,184,77,.15)}
.bento-card--stat{grid-column:2/3;grid-row:2/3;background:linear-gradient(135deg,#edf7f2,#f5faf7);border-color:rgba(125,184,158,.15)}
.bento-card--start{grid-column:3/4;grid-row:2/3;background:linear-gradient(135deg,#f0ecf8,#f7f5fb);border-color:rgba(155,142,196,.15)}

.bento-icon{width:44px;height:44px;border-radius:10px;display:grid;place-items:center;font-size:1.3rem;margin-bottom:16px}
.bento-icon--pink{background:var(--primary-soft);color:var(--primary)}
.bento-icon--sage{background:#edf7f2;color:var(--accent-sage)}
.bento-icon--gold{background:#fdf5e3;color:var(--accent-gold)}
.bento-icon--lavender{background:#f0ecf8;color:var(--accent-lavender)}

.bento-card h3{font-size:1.1rem;margin-bottom:6px}
.bento-card p{color:var(--muted);font-size:.88rem;margin:0;line-height:1.6}
.bento-link{display:inline-flex;align-items:center;gap:6px;margin-top:auto;padding-top:16px;color:var(--primary);font-weight:600;font-size:.85rem}
.bento-link::after{content:"→";transition:transform .2s}
.bento-card:hover .bento-link::after{transform:translateX(4px)}

.bento-stat-number{font-family:"Playfair Display",Georgia,serif;font-size:2.8rem;font-weight:700;color:var(--accent-sage);line-height:1}
.bento-stat-label{color:var(--muted);font-size:.82rem;margin-top:4px}

/* ===== CATEGORY STRIP ===== */
.category-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:48px}
.category-card{display:flex;align-items:center;gap:14px;padding:18px 20px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);text-decoration:none;color:inherit;transition:border-color .2s,box-shadow .2s,transform .2s}
.category-card:hover{border-color:var(--primary);box-shadow:var(--shadow-sm);transform:translateY(-2px)}
.category-card-icon{width:42px;height:42px;border-radius:10px;display:grid;place-items:center;font-size:1.2rem;flex-shrink:0}
.category-card-text{font-weight:600;font-size:.92rem}
.category-card-text small{display:block;font-weight:400;font-size:.78rem;color:var(--muted)}

/* ===== ABOUT PAGE ===== */
.about-hero{display:grid;grid-template-columns:1fr 0.7fr;gap:48px;align-items:center}
.about-story{font-size:1.05rem;color:var(--muted);line-height:1.8}
.about-story strong{color:var(--ink)}
.about-portrait{width:100%;aspect-ratio:3/4;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-md);background:var(--primary-soft)}
.about-portrait img{width:100%;height:100%;object-fit:cover}

.timeline{position:relative;padding-left:32px}
.timeline::before{content:"";position:absolute;left:11px;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--primary-soft),var(--primary),var(--primary-soft))}
.timeline-item{position:relative;padding:0 0 40px}
.timeline-item:last-child{padding-bottom:0}
.timeline-dot{position:absolute;left:-32px;top:4px;width:24px;height:24px;border-radius:50%;background:var(--surface);border:3px solid var(--primary);box-shadow:0 0 0 4px var(--primary-glow)}
.timeline-year{font-size:.78rem;font-weight:700;color:var(--primary);text-transform:uppercase;margin-bottom:4px}
.timeline-item h3{margin-bottom:4px;font-size:1.05rem}
.timeline-item p{color:var(--muted);margin:0;font-size:.92rem}

.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}

/* ===== BLOG ===== */
.blog-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:32px}
.filter-btn{min-height:38px;padding:0 16px;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--muted);font-weight:600;font-size:.84rem;cursor:pointer;transition:all .2s}
.filter-btn:hover,.filter-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}

.blog-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.blog-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .3s,box-shadow .3s;text-decoration:none;color:inherit}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.blog-card-thumb{width:100%;aspect-ratio:16/9;object-fit:cover;background:var(--primary-soft)}
.blog-card-body{padding:22px}
.blog-card-meta{display:flex;gap:12px;align-items:center;margin-bottom:10px;font-size:.78rem;color:var(--muted)}
.blog-card-meta .tag{font-size:.72rem}
.blog-card h3{font-size:1.08rem;margin-bottom:8px;line-height:1.4}
.blog-card p{color:var(--muted);font-size:.88rem;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ===== BLOG POST ===== */
.reading-progress{position:fixed;top:0;left:0;width:0;height:3px;background:linear-gradient(90deg,var(--primary),var(--accent-lavender));z-index:200;transition:width .1s linear}
.post-header{max-width:720px;margin:0 auto;padding-top:20px}
.post-header h1{font-size:clamp(2rem,4.5vw,3rem)}
.post-meta{display:flex;flex-wrap:wrap;gap:16px;color:var(--muted);font-size:.88rem;margin-bottom:24px}
.post-content{max-width:720px;margin:0 auto;font-size:1.02rem;line-height:1.85}
.post-content h2{margin-top:48px;font-size:1.6rem}
.post-content h3{margin-top:32px}
.post-content p{color:var(--muted)}
.post-content img{border-radius:var(--radius);margin:24px 0;box-shadow:var(--shadow-sm)}
.post-content blockquote{margin:24px 0;padding:20px 24px;border-left:4px solid var(--primary);background:var(--primary-soft);border-radius:0 var(--radius) var(--radius) 0;font-style:italic;color:var(--ink)}
.post-content blockquote p{color:var(--ink)}

.author-card{max-width:720px;margin:48px auto 0;display:flex;gap:20px;align-items:center;padding:24px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.author-avatar{width:64px;height:64px;border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--primary-soft)}
.author-avatar img{width:100%;height:100%;object-fit:cover}
.author-info h4{margin:0 0 4px;font-size:1rem}
.author-info p{margin:0;color:var(--muted);font-size:.85rem}

/* ===== PORTFOLIO ===== */
.case-grid{display:grid;gap:24px}
.case-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:box-shadow .3s}
.case-card:hover{box-shadow:var(--shadow-md)}
.case-card-header{padding:28px 28px 0;display:flex;justify-content:space-between;align-items:flex-start;gap:16px}
.case-card-body{padding:0 28px 28px;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-top:20px}
.case-field dt{color:var(--primary);font-size:.74rem;font-weight:800;text-transform:uppercase;margin-bottom:4px}
.case-field dd{margin:0;color:var(--muted);font-size:.92rem;line-height:1.6}
.case-result{padding:20px 28px;background:linear-gradient(135deg,var(--primary-soft),#fff5f7);border-top:1px solid var(--line)}
.case-result dt{color:var(--primary-dark)}
.case-result dd{color:var(--ink);font-weight:600;font-size:1rem}

.cv-section{display:flex;align-items:center;gap:24px;padding:32px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}
.cv-section p{color:var(--muted);margin:0;flex:1}

/* ===== STORE ===== */
.store-hero{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.store-hero-visual{aspect-ratio:4/5;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-md);background:var(--surface-warm)}
.store-hero-visual img{width:100%;height:100%;object-fit:cover}

.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}
.product-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;transition:transform .3s,box-shadow .3s}
.product-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.product-card-visual{width:100%;aspect-ratio:1;background:var(--surface-warm);display:grid;place-items:center;font-size:3rem;color:var(--accent-gold);border-bottom:1px solid var(--line)}
.product-card-visual img{width:100%;height:100%;object-fit:cover}
.product-card-body{padding:22px}
.product-card-story{color:var(--muted);font-size:.9rem;font-style:italic;margin-bottom:16px;line-height:1.6}
.product-card .btn{width:100%}

.quiz-section{background:linear-gradient(135deg,var(--primary-soft),var(--surface-warm));border:1px solid rgba(212,97,123,.1);border-radius:var(--radius-lg);padding:40px;text-align:center}
.quiz-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-top:24px}
.quiz-option{padding:24px;background:var(--surface);border:2px solid var(--line);border-radius:var(--radius);cursor:pointer;transition:border-color .2s,box-shadow .2s,transform .2s;text-align:left}
.quiz-option:hover,.quiz-option.selected{border-color:var(--primary);box-shadow:var(--shadow-glow);transform:translateY(-2px)}
.quiz-option h4{margin:0 0 6px;font-size:1rem}
.quiz-option p{margin:0;color:var(--muted);font-size:.85rem}

.combo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.combo-card{padding:28px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);text-align:center;transition:transform .3s,box-shadow .3s}
.combo-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.combo-icon{font-size:2.4rem;margin-bottom:12px}
.combo-card h3{font-size:1.1rem;margin-bottom:8px}
.combo-card p{color:var(--muted);font-size:.88rem;margin-bottom:16px}

/* ===== CONTACT ===== */
.intent-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:40px}
.intent-card{padding:28px;background:var(--surface);border:2px solid var(--line);border-radius:var(--radius-lg);cursor:pointer;text-align:center;transition:border-color .2s,box-shadow .2s,transform .2s}
.intent-card:hover,.intent-card.active{border-color:var(--primary);box-shadow:var(--shadow-glow);transform:translateY(-2px)}
.intent-icon{font-size:2rem;margin-bottom:12px}
.intent-card h3{font-size:1.05rem;margin-bottom:6px}
.intent-card p{color:var(--muted);font-size:.84rem;margin:0}

.contact-grid{display:grid;grid-template-columns:1fr minmax(280px,.6fr);gap:24px;align-items:start}
.contact-form{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm);display:grid;gap:16px}
.contact-form label{display:grid;gap:6px;color:var(--ink);font-weight:600;font-size:.9rem}
.contact-form input,.contact-form textarea,.contact-form select{width:100%;border:1px solid var(--line);border-radius:8px;padding:12px 14px;color:var(--ink);background:#fff;transition:border-color .2s,outline .2s}
.contact-form textarea{resize:vertical}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{outline:3px solid var(--primary-glow);border-color:var(--primary)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.hp-field{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-status{min-height:24px;margin:0;font-weight:700;font-size:.9rem}
.form-status.success{color:var(--accent-sage)}
.form-status.error{color:var(--primary)}

.contact-info{display:grid;gap:14px}
.contact-info-card{padding:22px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:14px;transition:border-color .2s;text-decoration:none;color:inherit}
.contact-info-card:hover{border-color:var(--primary)}
.contact-info-icon{width:42px;height:42px;border-radius:10px;display:grid;place-items:center;font-size:1.1rem;flex-shrink:0;background:var(--primary-soft);color:var(--primary)}
.contact-info-text{font-weight:600;font-size:.92rem}
.contact-info-text small{display:block;font-weight:400;color:var(--muted);font-size:.8rem}

/* ===== FOOTER ===== */
.site-footer{width:min(var(--max-w),calc(100% - 32px));margin:0 auto;padding:32px 0 42px;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:16px;color:var(--muted);font-size:.88rem}

/* ===== ANIMATIONS ===== */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}

@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes pulse-glow{0%,100%{box-shadow:0 0 0 0 var(--primary-glow)}50%{box-shadow:0 0 0 12px transparent}}

/* ===== RESPONSIVE ===== */
@media(max-width:900px){
    .menu-toggle{display:block}
    .nav-links{position:fixed;inset:var(--nav-h) 0 auto;display:none;padding:16px 20px 24px;background:var(--surface);border-bottom:1px solid var(--line);box-shadow:var(--shadow-lg);flex-direction:column;gap:0}
    .nav-links.open{display:flex}
    .nav-links a{min-height:48px;width:100%;border-bottom:1px solid var(--line);border-radius:0;padding:0 8px}

    .hero,.about-hero,.store-hero,.contact-grid{grid-template-columns:1fr}
    .hero,.store-hero{min-height:auto;padding-top:48px}
    .hero-portrait{width:200px;margin:0 auto}
    .bento{grid-template-columns:1fr 1fr}
    .bento-card--profile{grid-column:1/-1;grid-row:auto}
    .bento-card--blog,.bento-card--scent,.bento-card--stat,.bento-card--start{grid-column:auto;grid-row:auto}
    .category-strip,.combo-grid,.intent-grid,.values-grid{grid-template-columns:1fr 1fr}
    .blog-grid{grid-template-columns:1fr}
    .case-card-body{grid-template-columns:1fr}
    .about-portrait{max-width:400px;margin:0 auto}
}

@media(max-width:560px){
    .section{width:min(100% - 24px,var(--max-w));padding:56px 0}
    .navbar,.site-footer{width:min(100% - 24px,var(--max-w))}
    h1{font-size:2.2rem}
    h2{font-size:1.6rem}
    .hero-actions,.site-footer{flex-direction:column}
    .btn{width:100%}
    .bento,.category-strip,.combo-grid,.intent-grid,.values-grid{grid-template-columns:1fr}
    .form-row{grid-template-columns:1fr}
    .product-grid{grid-template-columns:1fr}
    .cv-section{flex-direction:column;text-align:center}
}
