@import url('https://fonts.googleapis.com/css2?family=Hubot+Sans:wght@400;500;600;700&family=Sk+Modernist:wght@400;500;600;700;800&display=swap');

:root{
--brand:#00514e;--brand-2:#003d3b;--brand-3:#002a29;
--brand-light:#e8f5f3;--brand-50:#f2fbf9;
--green:#24af76;--green-dark:#1d9463;--green-darker:#177a52;
--green-light:#e6f7ef;--green-50:#f0faf5;
--bg:#f6f8f9;--card:#fff;
--text:#0d1b1a;--text-2:#2d403f;--text-3:#7a8f8e;
--border:#dce6e5;--border-light:#eef3f2;
--danger:#d63b3b;
--shadow-s:0 1px 3px rgba(0,81,78,.05);
--shadow:0 2px 10px rgba(0,81,78,.06);
--shadow-m:0 8px 28px rgba(0,81,78,.08);
--shadow-l:0 16px 48px rgba(0,81,78,.1);
--r:10px;--r-s:7px;--r-l:14px;--r-xl:18px;
--ease:cubic-bezier(.4,0,.2,1);
--sk:'Sk Modernist',sans-serif;
--hubot:'Hubot Sans',sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--hubot);font-size:15px;line-height:1.65;color:var(--text-2);background:var(--bg);-webkit-font-smoothing:antialiased}
a{color:var(--green-dark);text-decoration:none;transition:color .2s}
a:hover{color:var(--green-darker)}
img{max-width:100%;display:block}
ul{list-style:none}
input,button,textarea,select{font-family:var(--hubot);font-size:inherit}
h1,h2,h3,h4,h5{font-family:var(--sk);font-weight:700;line-height:1.15;color:var(--text);letter-spacing:-.01em}
h1{font-size:clamp(1.8rem,4.5vw,2.8rem)}
h2{font-size:clamp(1.4rem,3vw,2rem)}
h3{font-size:1.12rem}
h4{font-size:.98rem}
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 20px}
.skip-link{position:absolute;top:-100%;left:50%;transform:translateX(-50%);background:var(--green);color:#fff;padding:8px 20px;border-radius:0 0 8px 8px;z-index:10000;font-weight:600}
.skip-link:focus{top:0}

/* NAV */
.navbar{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.95);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-light)}
.navbar.scrolled{box-shadow:var(--shadow)}
.navbar .container{display:flex;align-items:center;justify-content:space-between;height:62px}
.nav-logo{display:flex;align-items:center;gap:8px}
.nav-logo img{height:36px;width:auto}
.nav-links{display:flex;align-items:center;gap:22px}
.nav-links a{font-family:var(--sk);font-size:.86rem;font-weight:500;color:var(--text-2);position:relative;padding:4px 0;transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:var(--brand)}
.nav-links a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--green);border-radius:2px;transition:width .25s var(--ease)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-btn{display:inline-flex;align-items:center;gap:6px;background:var(--green);color:#fff!important;padding:9px 22px;border-radius:var(--r-s);font-family:var(--sk);font-weight:600;font-size:.82rem;border:none;cursor:pointer;transition:all .25s var(--ease);white-space:nowrap;line-height:1.3}
.nav-btn:hover{background:var(--green-dark);transform:translateY(-1px);box-shadow:0 4px 14px rgba(36,175,118,.25)}
.nav-btn::after{display:none!important}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;width:32px;height:32px;position:relative;z-index:1001}
.nav-toggle span{display:block;width:20px;height:2px;background:var(--brand);border-radius:2px;position:absolute;left:6px;transition:all .3s}
.nav-toggle span:nth-child(1){top:9px}
.nav-toggle span:nth-child(2){top:15px}
.nav-toggle span:nth-child(3){top:21px}
.nav-toggle.open span:nth-child(1){top:15px;transform:rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){top:15px;transform:rotate(-45deg)}
.nav-overlay{position:fixed;inset:0;background:rgba(0,81,78,.2);z-index:999;opacity:0;visibility:hidden;transition:all .3s}
.nav-overlay.active{opacity:1;visibility:visible}

/* HERO */
.hero{position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,42,41,.88) 0%,rgba(0,81,78,.72) 50%,rgba(0,81,78,.55) 100%)}
.hero .container{position:relative;z-index:2;padding:68px 20px 56px;display:flex;align-items:center;min-height:60vh}
.hero-inner{max-width:540px}
.hero h1{color:#fff;margin-bottom:10px}
.hero p{color:rgba(255,255,255,.75);font-size:1rem;max-width:480px;margin-bottom:22px;line-height:1.7}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 26px;border-radius:var(--r-s);font-family:var(--sk);font-weight:600;border:none;cursor:pointer;transition:all .25s var(--ease);line-height:1.3;font-size:.9rem}
.btn-green{background:var(--green);color:#fff}
.btn-green:hover{background:var(--green-dark);transform:translateY(-1px);box-shadow:0 4px 16px rgba(36,175,118,.25);color:#fff}
.btn-brand{background:var(--brand);color:#fff}
.btn-brand:hover{background:var(--brand-2);transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,81,78,.25);color:#fff}
.btn-white{background:#fff;color:var(--brand)}
.btn-white:hover{background:#f8fffa;transform:translateY(-1px);box-shadow:var(--shadow-m);color:var(--brand)}
.btn-outline{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.3)}
.btn-outline:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.5);color:#fff}
.btn-outline-dark{background:transparent;color:var(--brand);border:2px solid var(--border)}
.btn-outline-dark:hover{background:var(--brand-light);border-color:var(--green)}
.btn-dark{background:var(--brand);color:#fff}
.btn-dark:hover{background:var(--brand-2);transform:translateY(-1px);box-shadow:var(--shadow-m);color:#fff}
.btn-sm{padding:9px 18px;font-size:.82rem}
.btn-lg{padding:13px 30px;font-size:.95rem}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important;box-shadow:none!important}
.btn-block{width:100%;justify-content:center}

/* SECTIONS */
.section{padding:60px 0}
.section-alt{background:var(--card)}
.section-header{text-align:center;max-width:600px;margin:0 auto:32px}
.section-header p{margin-top:8px}
.section-label{display:inline-block;font-size:.7rem;font-weight:700;color:var(--green);text-transform:uppercase;letter-spacing:.12em;margin-bottom:6px}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center}
.about-video-wrap{position:relative;border-radius:var(--r-l);overflow:hidden;aspect-ratio:3/4;max-height:480px;background:var(--brand-3)}
.about-video-wrap video,.about-video-wrap img{width:100%;height:100%;object-fit:cover;display:block}
.about-video-wrap img{position:absolute;inset:0}
.about-content h2{margin-bottom:12px}
.about-content p{margin-bottom:10px}
.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:20px}
.about-stat{text-align:center;padding:16px 10px;background:var(--brand-light);border-radius:var(--r)}
.about-stat .num{font-family:var(--sk);font-size:1.3rem;font-weight:800;color:var(--brand)}
.about-stat .lbl{font-size:.74rem;color:var(--text-3);margin-top:2px}

/* VALUES */
.values-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}
.value-card{text-align:center;padding:24px 14px;background:var(--card);border-radius:var(--r);border:1px solid var(--border-light);box-shadow:var(--shadow-s);transition:all .3s var(--ease)}
.value-card:hover{border-color:var(--green);box-shadow:0 6px 20px rgba(36,175,118,.08);transform:translateY(-2px)}
.value-icon{width:42px;height:42px;border-radius:50%;background:var(--brand-light);color:var(--brand);display:flex;align-items:center;justify-content:center;margin:0 auto 10px;font-size:1rem}
.value-card h4{margin-bottom:3px;font-size:.86rem}
.value-card p{font-size:.78rem;color:var(--text-3)}

/* PRODUCTS - smaller on mobile */
.products-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.product-card{border-radius:var(--r);overflow:hidden;border:1px solid var(--border-light);background:var(--card)}
.product-card img{width:100%;display:block;height:220px;object-fit:cover}
@media(max-width:768px){
    .products-grid{grid-template-columns:repeat(2,1fr);gap:10px}
    .product-card img{height:160px}
}

/* ASSESSMENT INTRO */
.assessment-intro{position:relative;overflow:hidden;background:linear-gradient(160deg,var(--brand-3),var(--brand) 60%,var(--brand-2));padding:72px 0;color:#fff}
.assessment-intro::after{content:'';position:absolute;right:-100px;top:-100px;width:400px;height:400px;border-radius:50%;background:rgba(36,175,118,.06);filter:blur(80px)}
.assessment-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center;position:relative;z-index:1}
.assessment-intro h2{color:#fff;margin-bottom:10px}
.assessment-intro p{color:rgba(255,255,255,.6);margin-bottom:10px;font-size:.95rem}
.trait-preview{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.trait-preview-item{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:var(--r-s);padding:12px 14px;transition:all .3s}
.trait-preview-item:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.15)}
.trait-preview-item h4{color:#fff;font-size:.78rem;font-weight:600;margin-bottom:2px}
.trait-preview-item p{color:rgba(255,255,255,.45);font-size:.72rem;margin:0}
.trait-dot{display:inline-block;width:6px;height:6px;border-radius:50%;margin-right:4px;vertical-align:middle}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border-radius:var(--r-l);overflow:hidden;background:var(--card);box-shadow:var(--shadow-m);border:1px solid var(--border-light)}
.contact-image{position:relative;min-height:420px}
.contact-image img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.contact-form-wrap{padding:36px 32px}
.contact-form-wrap h2{margin-bottom:4px}
.contact-form-wrap>.subtitle{color:var(--text-3);font-size:.88rem;margin-bottom:22px}
.contact-info-list{display:flex;flex-direction:column;gap:12px;margin-bottom:22px}
.contact-item{display:flex;gap:10px;align-items:flex-start}
.contact-icon{width:36px;height:36px;border-radius:8px;background:var(--brand-light);color:var(--brand);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.82rem}
.contact-item h4{font-size:.82rem;margin-bottom:1px}
.contact-item p{font-size:.82rem;color:var(--text-3)}
.social-links{display:flex;gap:8px;margin-top:6px}
.social-link{width:34px;height:34px;border-radius:50%;background:var(--border-light);color:var(--text-2);display:flex;align-items:center;justify-content:center;font-size:.82rem;transition:all .25s var(--ease)}
.social-link:hover{background:var(--green);color:#fff;transform:translateY(-2px)}

/* FORMS */
.form-group{margin-bottom:14px}
.form-label{display:block;font-size:.82rem;font-weight:600;color:var(--text);margin-bottom:4px;font-family:var(--sk)}
.form-label .req{color:var(--danger);margin-left:2px}
.form-input,.form-select{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--r-s);font-size:.88rem;color:var(--text);background:#fff;transition:all .2s var(--ease);outline:none}
.form-input:focus,.form-select:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(36,175,118,.08)}
.form-input::placeholder{color:var(--text-3)}
textarea.form-input{resize:vertical;min-height:80px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.form-hint{font-size:.76rem;color:var(--text-3);margin-top:2px}
.alert{padding:10px 14px;border-radius:var(--r-s);font-size:.86rem;font-weight:500;margin-bottom:18px;display:flex;align-items:center;gap:8px}
.alert-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}
.alert-success{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}
.radio-group,.checkbox-group{display:flex;flex-wrap:wrap;gap:6px}
.radio-opt,.check-opt{display:flex;align-items:center;gap:6px;padding:8px 12px;border:1.5px solid var(--border);border-radius:var(--r-s);cursor:pointer;font-size:.84rem;transition:all .2s;flex-shrink:0}
.radio-opt:hover,.check-opt:hover{border-color:var(--green);background:var(--green-50)}
.radio-opt input,.check-opt input{accent-color:var(--green);width:16px;height:16px}
.radio-opt:has(input:checked),.check-opt:has(input:checked){border-color:var(--green);background:var(--green-light)}
.conditional{display:none}
.conditional.show{display:block}

/* STEP INDICATOR */
.step-indicator{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:24px}
.step-dot{width:32px;height:32px;border-radius:50%;background:var(--border-light);color:var(--text-3);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;font-family:var(--sk);transition:all .3s;flex-shrink:0}
.step-dot.active{background:var(--green);color:#fff}
.step-dot.done{background:var(--brand);color:#fff}
.step-line{width:40px;height:2px;background:var(--border-light);flex-shrink:0;transition:background .3s}
.step-line.done{background:var(--green)}
.step-title{text-align:center;font-family:var(--sk);font-size:.9rem;font-weight:600;color:var(--text);margin-bottom:18px}
@media(max-width:480px){.step-dot{width:28px;height:28px;font-size:.74rem;}
.step-line{width:28px;}
}

/* FOOTER */
.site-footer{background:var(--brand-3);color:rgba(255,255,255,.5);padding:30px 0 16px}
.footer-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.footer-content p{font-size:.78rem;color:rgba(255,255,255,.3)}

/* AUTH */
.auth-page{min-height:100vh;display:flex}
.auth-side{flex:0 0 40%;background:linear-gradient(160deg,var(--brand-3),var(--brand) 60%,var(--brand-2));display:flex;flex-direction:column;justify-content:center;align-items:center;padding:48px 36px;color:#fff;position:relative;overflow:hidden}
.auth-side::before{content:'';position:absolute;inset:0;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='20' cy='20' r='14' fill='%23fff' fill-opacity='.5'/%3E%3C/svg%3E%3C/svg%3E");background-size:40px 40px;background-size:40px 40px}
.auth-side>*{position:relative;z-index:1}
.auth-side .logo{display:flex;align-items:center;gap:8px;font-family:var(--sk);font-size:1.05rem;font-weight:800;margin-bottom:24px}
.auth-side .logo img{height:34px}
.auth-side .logo span{color:rgba(255,255,255,.5)}
.auth-side h2{color:#fff;margin-bottom:8px;font-size:1.3rem}
.auth-side p{color:rgba(255,255,255,.6);font-size:.88rem;max-width:300px;text-align:center;line-height:1.7}
.trust-items{margin-top:24px;display:flex;flex-direction:column;gap:10px;width:100%}
.trust-item{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.65);font-size:.84rem}
.trust-item i{color:var(--green);width:18px;text-align:center}
.auth-main{flex:1;display:flex;align-items:center;justify-content:center;padding:32px 24px;background:var(--bg);overflow-y:auto}
.auth-card{width:100%;max-width:520px}
.auth-card h1{font-size:1.35rem;margin-bottom:4px}
.auth-card .subtitle{color:var(--text-3);font-size:.86rem;margin-bottom:22px}
.auth-card .alt-link{text-align:center;margin-top:16px;font-size:.84rem;color:var(--text-3)}
.auth-card .alt-link a{font-weight:600}

/* DASHBOARD */
.dash-page{min-height:100vh;background:var(--bg)}
.dash-header{background:var(--card);border-bottom:1px solid var(--border-light);padding:0 20px;height:58px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}
.dash-header .logo{display:flex;align-items:center;gap:8px}
.dash-header .logo img{height:30px}
.dash-header-right{display:flex;align-items:center;gap:12px}
.dash-user-info{display:flex;align-items:center;gap:8px;font-size:.84rem}
.dash-avatar{width:30px;height:30px;border-radius:50%;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.72rem;font-family:var(--sk)}
.dash-body{max-width:920px;margin:0 auto;padding:28px 16px}
.dash-welcome h1{font-size:1.35rem;margin-bottom:4px}
.dash-welcome p{color:var(--text-3);font-size:.88rem}
.dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}
.dash-card{background:var(--card);border-radius:var(--r);border:1px solid var(--border-light);padding:24px;box-shadow:var(--shadow-s)}
.dash-card-icon{width:42px;height:42px;border-radius:var(--r-s);display:flex;align-items:center;justify-content:center;font-size:1rem;margin-bottom:14px;color:var(--brand)}
.dash-card h3{font-size:.94rem;margin-bottom:4px}
.dash-card p{font-size:.84rem;color:var(--text-3);margin-bottom:14px}
.dash-card-full{grid-column:1/-1}
.status-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:50px;font-size:.76rem;font-weight:600;font-family:var(--sk)}
.status-pending{background:#fef3c7;color:#92400e}
.status-complete{background:var(--green-light);color:var(--green-darker)}
.status-none{background:var(--border-light);color:var(--text-3)}
.mini-scores{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:14px}
.mini-score{text-align:center;padding:8px 6px;background:var(--bg);border-radius:var(--r-s)}
.mini-score .val{font-family:var(--sk);font-size:1.1rem;font-weight:800;color:var(--text)}
.mini-score .lbl{font-size:.7rem;color:var(--text-3);margin-top:1px}

/* ASSESSMENT */
.assessment-page{min-height:calc(100vh - 62px);display:flex;flex-direction:column}
.assessment-body{flex:1;display:flex;align-items:center;justify-content:center;padding:32px 16px}
.question-card{background:var(--card);border-radius:var(--r-xl);box-shadow:var(--shadow-l);border:1px solid var(--border-light);max-width:640px;width:100%;overflow:hidden}
.question-progress{background:var(--border-light);height:4px;width:100%}
.question-progress-fill{height:100%;background:linear-gradient(90deg,var(--green-dark),var(--green));transition:width .4s var(--ease)}
.question-meta{display:flex;justify-content:space-between;align-items:center;padding:14px 24px 0;font-size:.78rem;color:var(--text-3);font-weight:500;font-family:var(--sk)}
.question-meta .pt{color:var(--green-dark);font-weight:700}
.question-enc{text-align:center;padding:4px 24px 0;font-size:.78rem;color:var(--text-3);font-style:italic;min-height:22px}
.question-body{padding:16px 24px 20px}
.question-text{font-size:1rem;font-weight:600;color:var(--text);line-height:1.5;margin-bottom:20px;min-height:48px;font-family:var(--sk)}
.likert-scale{display:flex;gap:6px}
.likert-option{flex:1;position:relative}
.likert-option input{position:absolute;opacity:0;width:0;height:0}
.likert-label{display:block;text-align:center;padding:12px 6px;border:2px solid var(--border);border-radius:var(--r-s);cursor:pointer;transition:all .2s var(--ease);font-size:.78rem;font-weight:500;color:var(--text-2);background:#fff;line-height:1.3}
.likert-label:hover{border-color:var(--green);background:var(--green-50)}
.likert-option input:checked+.likert-label{border-color:var(--green);background:var(--green);color:#fff;font-weight:600;box-shadow:0 3px 10px rgba(36,175,118,.2)}
.likert-option input:focus-visible+.likert-label{outline:3px solid rgba(36,175,118,.3);outline-offset:2px}
.question-nav{display:flex;justify-content:space-between;align-items:center;padding:0 24px 20px;gap:10px}
.question-nav .btn{min-width:100px;justify-content:center}
.skip-warning{color:var(--danger);font-size:.78rem;font-weight:500;opacity:0;transition:opacity .2s;text-align:center;padding:0 24px 8px}
.skip-warning.vis{opacity:1}

/* RESULTS */
.results-page{padding:32px 0 56px}
.results-header{text-align:center;margin-bottom:32px}
.results-header .cbadge{display:inline-flex;align-items:center;gap:6px;background:var(--green-light);color:var(--green-darker);padding:5px 14px;border-radius:50px;font-size:.8rem;font-weight:600;margin-bottom:12px;font-family:var(--sk)}
.results-header h1{margin-bottom:6px}
.results-header p{max-width:460px;margin:0 auto;font-size:.92rem}
.summary-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:32px}
.summary-card{background:var(--card);border-radius:var(--r);padding:18px;border:1px solid var(--border-light);box-shadow:var(--shadow-s);text-align:center}
.summary-card .sv{font-family:var(--sk);font-size:.96rem;font-weight:800;color:var(--brand)}
.summary-card .sl{font-size:.76rem;color:var(--text-3);font-weight:500;margin-top:2px}
.chart-section{background:var(--card);border-radius:var(--r-xl);padding:28px;border:1px solid var(--border-light);box-shadow:var(--shadow);margin-bottom:32px}
.chart-section h2{margin-bottom:24px;font-size:1.15rem}
.chart-bars{display:flex;flex-direction:column;gap:14px}
.chart-bar-row{display:flex;align-items:center;gap:12px}
.chart-bar-label{width:160px;flex-shrink:0;font-size:.82rem;font-weight:600;color:var(--text-2);text-align:right;font-family:var(--sk)}
.chart-bar-track{flex:1;height:28px;background:var(--border-light);border-radius:7px;overflow:hidden}
.chart-bar-fill{height:100%;border-radius:7px;transition:width 1s var(--ease);width:0}
.chart-bar-value{width:44px;flex-shrink:0;font-family:var(--sk);font-size:.88rem;font-weight:700;color:var(--text)}
.trait-details{display:flex;flex-direction:column;gap:16px}
.trait-detail-card{background:var(--card);border-radius:var(--r);border:1px solid var(--border-light);box-shadow:var(--shadow-s);overflow:hidden;transition:box-shadow .3s}
.trait-detail-card:hover{box-shadow:var(--shadow)}
.trait-detail-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border-light)}
.trait-detail-header .left{display:flex;align-items:center;gap:10px}
.trait-color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.trait-detail-header h3{font-size:.96rem}
.score-badge{font-family:var(--sk);font-size:.96rem;font-weight:800;padding:4px 12px;border-radius:50px;background:var(--border-light)}
.trait-detail-body{padding:18px 20px}
.trait-detail-body .interp{font-size:.9rem;line-height:1.7;color:var(--text-2);margin-bottom:14px}
.facet-scores{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr);gap:8px}
.facet-item{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;background:var(--bg);border-radius:var(--r-s);font-size:.82rem}
.facet-item .fn{color:var(--text-2);font-weight:500}
.facet-item .fs{font-family:var(--sk);font-weight:700;color:var(--text)}
.results-actions{text-align:center;margin-top:36px;padding-top:28px;border-top:1px solid var(--border-light);display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.download-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;border-radius:var(--r-s);font-family:var(--sk);font-weight:600;font-size:.84rem;border:1.5px solid var(--border);cursor:pointer;transition:all .25s var(--ease);background:var(--card);color:var(--brand)}
.download-btn:hover{border-color:var(--green);background:var(--green-50);color:var(--green-dark)}
.print-btn{position:fixed;top:20px;right:20px;padding:12px 24px;background:var(--green);color:#fff;border:none;border-radius:var(--r-s);font-family:var(--sk);font-size:12pt;font-weight:600;cursor:pointer;box-shadow:0 4px 16px rgba(36,175,118,.3);z-index:9999}
.print-btn:hover{background:var(--green-dark)}

/* Print styles — hide everything except report */
@media print{
.navbar,.dash-header,.admin-topbar,.admin-sidebar,.results-actions,.print-btn,.toast-container,.site-footer{display:none!important}
.results-page{padding:0!important}
.results-header{margin-bottom:20px!important;padding-top:0!important}
.summary-row{margin-bottom:24px!important}
.chart-section{box-shadow:none!important;border:none!important;padding:16px 0!important;margin-bottom:24px!important}
.trait-details .trait-detail-card{box-shadow:none!important;border:1px solid #ddd!important;break-inside:avoid;}
body{background:#fff!important;font-size:12pt!important;line-height:1.5!important}
}

/* ADMIN */
.admin-layout{display:flex;min-height:100vh}
.admin-sidebar{width:250px;background:linear-gradient(180deg,var(--brand-3),var(--brand));color:#fff;position:fixed;top:0;left:0;bottom:0;z-index:500;display:flex;flex-direction:column;transition:transform .3s}
.admin-sidebar .sidebar-logo{padding:18px 16px;display:flex;align-items:center;gap:8px;border-bottom:1px solid rgba(255,255,255,.06)}
.admin-sidebar .sidebar-logo img{height:28px}
.admin-sidebar .sidebar-logo span{color:rgba(255,255,255,.5);font-family:var(--sk);font-weight:700;font-size:.88rem;margin-left:4px;}
.admin-sidebar .sidebar-label{padding:18px 16px 6px;font-size:.66rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.25);font-family:var(--sk)}
.admin-sidebar nav{flex:1;padding:0 10px;display:flex;flex-direction:column;gap:1px}
.admin-sidebar nav a{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--r-s);font-size:.84rem;font-weight:500;color:rgba(255,255,255,.5);transition:all .2s}
.admin-sidebar nav a:hover{background:rgba(255,255,255,.05);color:rgba(255,255,255,.8)}
.admin-sidebar nav a.active{background:rgba(36,175,118,.12);color:var(--green)}
.admin-sidebar nav a i{width:18px;text-align:center;font-size:.82rem}
.sidebar-footer{padding:14px 10px;border-top:1px solid rgba(255,255,255,.06)}
.sidebar-footer a{display:flex;align-items:center;gap:8px;padding:9px 10px;border-radius:var(--r-s);font-size:.84rem;color:rgba(255,255,255,.35);transition:all .2s}
.sidebar-footer a:hover{background:rgba(255,255,255,.05);color:rgba(255,255,255,.65)}
.admin-main{flex:1;margin-left:250px;background:var(--bg);min-height:100vh}
.admin-topbar{background:var(--card);border-bottom:1px solid var(--border-light);height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 22px;position:sticky;top:0;z-index:400}
.admin-topbar h2{font-size:1.05rem}
.admin-topbar-right{display:flex;align-items:center;gap:12px}
.admin-topbar .admin-name{font-size:.84rem;font-weight:500;color:var(--text-2)}
.admin-avatar{width:30px;height:30px;border-radius:50%;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.72rem;font-family:var(--sk)}
.admin-content{padding:24px}
.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,min-width:180px,1fr);gap:14px;margin-bottom:24px}
.stat-card{background:var(--card);border-radius:var(--r);border:1px solid var(--border-light);padding:18px;box-shadow:var(--shadow-s)}
.stat-card .stat-icon{width:38px;height:38px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.88rem;margin-bottom:12px;color:var(--brand);background:var(--brand-light)}
.stat-card .stat-val{font-family:var(--sk);font-size:1.5rem;font-weight:800;color:var(--text);margin-bottom:1px}
.stat-card .stat-lbl{font-size:.78rem;color:var(--text-3);font-weight:500}
.admin-table-wrap{background:var(--card);border-radius:var(--r);border:1px solid var(--border-light);box-shadow:var(--shadow-s);overflow:hidden}
.admin-table-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-light);flex-wrap:wrap;gap:10px}
.admin-table-header h3{font-size:.94rem}
.admin-table{width:100%;border-collapse:collapse}
.admin-table th{text-align:left;padding:10px 16px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-3);background:var(--bg);border-bottom:1px solid var(--border-light);font-family:var(--sk)}
.admin-table td{padding:12px 16px;font-size:.84rem;border-bottom:1px solid var(--border-light);color:var(--text-2)}
.admin-table tr:last-child td{border-bottom:none}
.admin-table tr:hover td{background:var(--green-50)}
.table-actions{display:flex;gap:4px}
.table-btn{padding:4px 10px;border-radius:var(--r-s);font-size:.76rem;font-weight:600;border:none;cursor:pointer;transition:all .2s;font-family:var(--sk)}
.table-btn-view{background:var(--green-light);color:var(--green-darker)}
.table-btn-view:hover{background:var(--green);color:#fff}
.table-btn-danger{background:#fef2f2;color:#991b1b}
.table-btn-danger:hover{background:var(--danger);color:#fff}
.table-btn-edit{background:var(--brand-light);color:var(--brand)}
.table-btn-edit:hover{background:var(--brand);color:#fff}
.toggle-switch{position:relative;width:42px;height:22px;cursor:pointer;display:inline-block}
.toggle-switch input{opacity:0;width:0;height:0;position:absolute}
.toggle-slider{position:absolute;inset:0;background:var(--border);border-radius:11px;transition:all .25s}
.toggle-slider::before{content:'';position:absolute;left:2px;top:2px;width:18px;height:18px;border-radius:50%;background:#fff;transition:all .25s;box-shadow:var(--shadow-s)}
.toggle-switch input:checked+.toggle-slider{background:var(--green)}
.toggle-switch input:checked+.toggle-slider::before{transform:translateX(20px)}
.admin-modal-overlay{position:fixed;inset:0;background:rgba(0,81,78,.3);z-index:2000;display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;visibility:hidden;transition:all .25s}
.admin-modal-overlay.active{opacity:1;visibility:visible}
.admin-modal{background:var(--card);border-radius:var(--r-xl);box-shadow:var(--shadow-l);max-width:440px;width:100%;max-height:90vh;overflow-y:auto;transform:translateY(16px);transition:transform .25s var(--ease)}
.admin-modal-overlay.active .admin-modal{transform:translateY(0)}
.admin-modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border-light)}
.admin-modal-header h3{font-size:1rem}
.admin-modal-close{background:none;border:none;font-size:1.1rem;color:var(--text-3);cursor:pointer;padding:4px}
.admin-modal-close:hover{color:var(--text);}
.admin-modal-body{padding:22px}
.search-input{padding:7px 12px 7px 32px;border:1.5px solid var(--border);border-radius:var(--r-s);font-size:.84rem;outline:none;transition:border-color .2s;background:var(--bg) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='%237a8f8e' viewBox='0 0 16 16'%3E%3Cpath d='M11.742 10.344a6.5 6.5 0 10-1.397 1.398h-.001l3.85 3.85a1 1 0 001.415-1.414l-3.85-3.85zm-5.242.656a5 5 0 110-10 5 5 0 010 10z'/%3E%3C/svg%3E/svg%3E/svg%3E") 12px center no-repeat;}
.search-input:focus{border-color:var(--green)}
.admin-mobile-toggle{display:none!important;align-items:center;justify-content:center;width:34px;height:34px;border:none;background:var(--border-light);border-radius:var(--r-s);cursor:pointer;font-size:.95rem;color:var(--text-2)}
.admin-empty{text-align:center;padding:36px 16px;color:var(--text-3)}
.admin-empty i{font-size:2rem;margin-bottom:10px;opacity:.35}
.toast-container{position:fixed;bottom:16px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:6px}
.toast{background:var(--brand);color:#fff;padding:10px 18px;border-radius:var(--r-s);font-size:.84rem;font-weight:500;box-shadow:var(--shadow-l);transform:translateX(120%);transition:transform .3s var(--ease);max-width:300px}
.toast.show{transform:translateX(0)}
.toast-error{border-left:4px solid var(--danger)}
.toast-success{border-left:4px solid var(--green)}

/* RESPONSIVE */
@media(max-width:992px){
.about-grid{grid-template-columns:1fr 1fr;gap:32px}
.about-video-wrap{max-height:340px;aspect-ratio:auto;height:340px}
.products-grid{grid-template-columns:1fr 1fr}
.chart-bar-label{width:120px;font-size:.78rem}
.admin-sidebar{transform:translateX(-100%)}
.admin-sidebar.open{transform:translateX(0)}
.admin-main{margin-left:250px}
.admin-mobile-toggle{display:flex!important}
}
@media(max-width:768px){
.nav-links{position:fixed;top:0;right:-100%;width:260px;height:100vh;background:#fff;flex-direction:column;padding:68px 20px 20px;box-shadow:-4px 0 16px rgba(0,0,0,.1);transition:right .3s;z-index:1000;gap:0}
.nav-links.open{right:0}
.nav-links a{padding:11px 0;font-size:.92rem;border-bottom:1px solid var(--border-light);width:100%}
.nav-links a::after{display:none}
.nav-toggle{display:block}
.hero .container{padding:56px 20px 44px;min-height:auto}
.section{padding:48px 0}
.assessment-intro{padding:56px 0}
.trait-preview{grid-template-columns:1fr 1fr}
.values-grid{grid-template-columns:1fr 1fr}
.form-row,.form-row-3{grid-template-columns:1fr}
.auth-side{display:none}
.auth-main{padding:24px 16px}
.auth-card{max-width:100%}
.dash-grid{grid-template-columns:1fr}
.likert-scale{flex-direction:column;gap:5px}
.likert-label{padding:10px 12px;text-align:left}
.question-body{padding:14px 18px 18px}
.question-meta{padding:10px 18px 0}
.question-nav{padding:0 18px 18px}
.skip-warning{padding:0 18px 8px}
.chart-section{padding:18px 14px;margin-bottom:24px}
.chart-bar-row{flex-wrap:wrap;gap:6px}
.chart-bar-label{width:100%;text-align:left}
.chart-bar-track{min-height:24px}
.chart-bar-value{width:auto}
.trait-detail-header{flex-direction:column;align-items:flex-start;gap:8px;padding:14px 16px}
.trait-detail-body{padding:14px 16px}
.facet-scores{grid-template-columns:1fr}
.trait-detail-header h3{font-size:.92rem}
.admin-content{padding:16px 12px}
.admin-topbar{padding:0 14px}
.admin-topbar h2{font-size:1rem}
.footer-content{flex-direction:column;text-align:center}
.products-grid{grid-template-columns:1fr 1fr}
.product-card img{height:140px}
.mini-scores{grid-template-columns:1fr 1fr}
.admin-stats{grid-template-columns:1fr 1fr}
.step-dot{width:26px;height:26px;font-size:.72rem}
.step-line{width:24px}
.admin-table th,.admin-table td{padding:10px 14px;}
.admin-table th{font-size:.68rem}
.admin-table td{font-size:.8rem}
.footer-content p{font-size:.76rem}
.values-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
.container{padding:0 14px}
.hero-actions{flex-direction:column}
.hero-actions .btn{width:100%;justify-content:center}
.values-grid{grid-template-columns:1fr}
.products-grid{grid-template-columns:1fr}
.mini-scores{grid-template-columns:1fr 1fr}
.admin-stats{grid-template-columns:1fr 1fr}
.step-dot{width:24px;height:24px;font-size:.7rem}
.step-line{width:22px}
}
@media(prefers-reduced-motion:reduce{
*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
.chart-bar-fill{transition:none!important}
}