:root{--color-brand-900: #004a00;--color-brand-800: #0f350f;--color-brand-700: #0f350f;--color-brand-600: #3d8a3e;--color-brand-500: #5fbc60;--color-brand-400: #7ad27b;--color-brand-300: #7ad27b;--color-brand-200: #b8e5b9;--color-brand-100: #d9f0da;--color-brand-900-rgb: 0, 74, 0;--color-brand-500-rgb: 95, 188, 96;--color-success: #22c55e;--color-warning: #f59e0b;--color-error: #ef4444;--color-info: #3b82f6;--color-danger: #c0392b;--color-badge-exclusive-bg: #fef3cd;--color-badge-exclusive-text: #856404;--color-badge-standard-bg: #cce5ff;--color-badge-standard-text: #004085;--color-badge-subscription-bg: #d4edda;--color-badge-subscription-text: #155724;--color-badge-shared-bg: #e2d5f1;--color-badge-shared-text: #5a2d82;--color-background: #f5f9f5;--color-surface: #ffffff;--color-surface-muted: #eef6ef;--color-text-primary: #123212;--color-text-secondary: #2f5b2f;--color-text-tertiary: #6b8a6b;--color-heading: #004a00;--color-border: #d1e4d1;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--container-xl: 1280px;--font-primary: "Inter", system-ui, sans-serif;--font-mono: "Fira Code", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .15);--transition-fast: .15s;--transition-base: .2s;--transition-slow: .3s;--ease-in-out: cubic-bezier(.4, 0, .2, 1);--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-modal-backdrop: 500;--z-modal: 600;--z-tooltip: 800;--background-color: var(--color-background);--card-background: var(--color-surface);--text-color: var(--color-text-primary);--text-muted: var(--color-text-tertiary);--border-color: var(--color-border);--primary-color: var(--color-brand-500);--primary-hover: var(--color-brand-600);--background-hover: var(--color-surface-muted)}:root[data-theme=dark]{--color-background: #0b120c;--color-surface: #131d14;--color-surface-muted: #1a2a1b;--color-text-primary: #e5f6e5;--color-text-secondary: #c5e8c5;--color-text-tertiary: #8ba88c;--color-heading: #7ad27b;--color-border: #2d5a2d}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}:root{font-family:var(--font-primary, system-ui, Avenir, Helvetica, Arial, sans-serif);line-height:1.5;font-weight:var(--font-normal);color-scheme:light dark;color:var(--color-text-primary);background-color:var(--color-background);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-primary);background:var(--color-background);color:var(--color-text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;margin:0;min-width:20rem}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}a{color:var(--color-brand-500);text-decoration:none;font-weight:var(--font-medium)}a:hover{color:var(--color-brand-400)}button{cursor:pointer;border:none;background:none}ul,ol{list-style:none}h1{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--color-heading);line-height:1.1}h2{font-size:var(--text-2xl);font-weight:var(--font-semibold);color:var(--color-heading)}h3{font-size:var(--text-xl);font-weight:var(--font-semibold)}p{margin-bottom:var(--space-md)}code{font-family:var(--font-mono);background:var(--color-surface-muted);padding:.2em .4em;border-radius:var(--radius-sm)}main{flex:1}.container{width:100%;max-width:var(--container-xl);margin:0 auto;padding:0 var(--space-md)}:focus-visible{outline:2px solid var(--color-brand-500);outline-offset:2px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}::-webkit-scrollbar{width:.5rem;height:.5rem}::-webkit-scrollbar-track{background:var(--color-surface);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb{background:var(--color-brand-700);border-radius:var(--radius-full);border:2px solid var(--color-surface)}::-webkit-scrollbar-thumb:hover{background:var(--color-brand-500)}*{scrollbar-width:thin;scrollbar-color:var(--color-brand-700) var(--color-surface)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.gap-1{gap:var(--space-md)}.gap-1\.5{gap:var(--space-lg)}.mt-1\.5{margin-top:var(--space-lg)}.m-0{margin:0}.text-sm{font-size:var(--text-sm)}.button-unstyled{background:none;border:none;cursor:pointer;font-size:inherit;padding:0}.ganji-button{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);font-weight:var(--font-medium);border-radius:var(--radius-md);border:none;transition:all var(--transition-fast) var(--ease-in-out);cursor:pointer}.ganji-button--primary{background:var(--color-brand-500);color:#fff}.ganji-button--primary:hover:not(:disabled){background:var(--color-brand-600)}.ganji-button--secondary{background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border)}.ganji-button--secondary:hover:not(:disabled){background:var(--color-surface-muted)}.ganji-button--ghost{background:transparent;color:var(--color-text-secondary)}.ganji-button--ghost:hover:not(:disabled){background:var(--color-surface-muted)}.ganji-button--danger{background:var(--color-error);color:#fff}.ganji-button--danger:hover:not(:disabled){background:var(--color-danger)}.ganji-button--sm{padding:var(--space-xs) var(--space-sm);font-size:var(--text-sm)}.ganji-button--md{padding:var(--space-sm) var(--space-md);font-size:var(--text-base)}.ganji-button--lg{padding:var(--space-md) var(--space-lg);font-size:var(--text-lg)}.ganji-button--full-width{width:100%}.ganji-button:disabled{opacity:.5;cursor:not-allowed}.ganji-spinner{border:3px solid var(--color-border);border-top-color:var(--color-brand-500);border-radius:50%;animation:ganji-spin .8s linear infinite}.ganji-spinner--sm{width:16px;height:16px;border-width:2px}@keyframes ganji-spin{to{transform:rotate(360deg)}}.ganji-header{display:flex;align-items:center;justify-content:space-between;padding-right:var(--space-lg);background:var(--color-background);border-bottom:1px solid transparent;position:sticky;top:0;z-index:var(--z-sticky);transition:border-color var(--transition-fast)}.ganji-header--scrolled{border-bottom-color:var(--color-brand-500)}.ganji-header__logo{display:flex;align-items:center;text-decoration:none}.ganji-header__logo-image{height:5rem;width:auto;object-fit:contain}.ganji-header__nav{display:flex;gap:var(--space-lg);margin-left:auto}.ganji-header__nav--desktop{display:none;padding-right:var(--space-lg)}@media(min-width:768px){.ganji-header__nav--desktop{display:flex}}.ganji-header__nav-link{color:var(--color-text-secondary);text-decoration:none;transition:color var(--transition-fast)}.ganji-header__nav-link:hover{color:var(--color-brand-500)}.ganji-header__site-title-link{color:var(--color-brand-500);text-decoration:none;font-weight:600;font-size:var(--text-sm);transition:color var(--transition-fast)}.ganji-header__site-title-link:hover{color:var(--color-brand-600)}.ganji-header__auth{display:none;align-items:center;gap:var(--space-md)}@media(min-width:768px){.ganji-header__auth{display:flex}}.ganji-header__username{color:var(--color-text-secondary);font-size:var(--text-sm)}.ganji-header__username-link{color:var(--color-text-secondary);font-size:var(--text-sm);text-decoration:none;transition:color var(--transition-fast)}.ganji-header__username-link:hover{color:var(--color-brand-500)}.ganji-header__mobile-toggle{display:flex;flex-direction:column;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;background:transparent;border:none;cursor:pointer}@media(min-width:768px){.ganji-header__mobile-toggle{display:none}}.ganji-header__hamburger{width:1.5rem;height:.125rem;background:var(--color-text-primary);position:relative}.ganji-header__hamburger:before,.ganji-header__hamburger:after{content:"";position:absolute;width:1.5rem;height:.125rem;background:var(--color-text-primary);left:0}.ganji-header__hamburger:before{top:-.375rem}.ganji-header__hamburger:after{top:.375rem}.ganji-header__mobile-overlay{position:fixed;inset:0;background:#00000080;z-index:var(--z-modal)}.ganji-header__mobile-nav{position:absolute;top:3.75rem;right:0;left:0;background:var(--color-surface);padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md);border-bottom:1px solid var(--color-border)}.ganji-verification-banner{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,#fff3cd,#ffeaa7);border-bottom:2px solid #ffc107;padding:var(--space-md) var(--space-lg);gap:var(--space-md);position:sticky;top:80px;z-index:calc(var(--z-sticky) - 1);animation:slideDown .3s var(--ease-in-out)}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.ganji-verification-banner__content{display:flex;align-items:center;gap:var(--space-md);flex:1}.ganji-verification-banner__icon{font-size:1.5rem;flex-shrink:0}.ganji-verification-banner__text{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-sm);font-size:var(--text-sm);color:#856404}.ganji-verification-banner__text strong{font-weight:var(--font-semibold)}.ganji-verification-banner__resend{background:none;border:none;color:#856404;text-decoration:underline;cursor:pointer;padding:0;font-size:var(--text-sm);font-weight:var(--font-medium)}.ganji-verification-banner__resend:hover{color:#533f03}.ganji-verification-banner__close{background:transparent;border:none;color:#856404;font-size:1.25rem;cursor:pointer;padding:var(--space-xs);line-height:1;flex-shrink:0;border-radius:var(--radius-sm);transition:background var(--transition-fast) var(--ease-in-out)}.ganji-verification-banner__close:hover{background:#8564041a}:root[data-theme=dark] .ganji-verification-banner{background:linear-gradient(135deg,#4a3c1a,#665010);border-bottom-color:#b8860b}:root[data-theme=dark] .ganji-verification-banner__text,:root[data-theme=dark] .ganji-verification-banner__resend,:root[data-theme=dark] .ganji-verification-banner__close{color:#ffd54f}:root[data-theme=dark] .ganji-verification-banner__resend:hover{color:#ffe082}:root[data-theme=dark] .ganji-verification-banner__close:hover{background:#ffd54f1a}@media(max-width:768px){.ganji-verification-banner{padding:var(--space-sm) var(--space-md);top:60px}.ganji-verification-banner__text{font-size:var(--text-xs)}.ganji-verification-banner__icon{font-size:1.25rem}}.ganji-footer{position:fixed;bottom:0;left:0;width:100%;z-index:100;background:var(--color-surface);border-top:1px solid var(--color-brand-500);box-shadow:0 -4px 20px #0003,0 -2px 10px rgba(var(--color-brand-500-rgb),.25);transition:transform .3s cubic-bezier(.16,1,.3,1);transform:translateY(calc(100% - 60px))}.ganji-footer--expanded{transform:translateY(0)}.ganji-footer:not(.ganji-footer--expanded):hover{transform:translateY(calc(100% - 4.0625rem))}.ganji-footer__bar{height:3.75rem;cursor:pointer;display:flex;align-items:center;border-bottom:1px solid transparent;transition:background-color .2s,border-color .2s}.ganji-footer__bar:hover{background-color:rgba(var(--color-brand-500-rgb),.05)}.ganji-footer--expanded .ganji-footer__bar{border-bottom-color:var(--color-border)}.ganji-footer__container{padding:0 var(--space-md)}.ganji-footer__bar-container{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;width:100%;height:100%}.ganji-footer__bar-left{display:flex;align-items:center;gap:var(--space-md);justify-self:start}.ganji-footer__bar-center{display:flex;align-items:center;justify-content:center;justify-self:center;gap:var(--space-xs)}.ganji-footer__bar-right{display:flex;align-items:center;justify-self:end;gap:var(--space-md)}.ganji-footer__copyright{color:var(--color-brand-400);font-size:var(--text-xs);white-space:nowrap;display:none}@media(min-width:640px){.ganji-footer__copyright{display:block}}.ganji-footer__page-title{color:var(--color-brand-400);font-size:var(--text-sm);font-weight:var(--font-medium)}.ganji-footer__brand{display:flex;align-items:center;gap:var(--space-sm)}.ganji-footer__brand-icon{height:1.5rem;width:auto;object-fit:contain}.ganji-footer__tagline{color:var(--color-brand-400);font-size:var(--text-sm);margin-left:var(--space-sm)}.ganji-footer__tagline--desktop{display:none}@media(min-width:768px){.ganji-footer__tagline--desktop{display:inline}}.ganji-footer__indicator{display:flex;align-items:center;justify-content:center;color:var(--color-brand-500)}.ganji-footer__arrow{transition:transform .3s ease}.ganji-footer__arrow--rotated{transform:rotate(180deg)}.ganji-footer__social{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-md)}.ganji-footer__social-link{display:flex;align-items:center;justify-content:center;padding:var(--space-xs);color:var(--color-brand-400);transition:color .2s,transform .2s}.ganji-footer__social-link:hover{color:var(--color-brand-500);transform:translateY(-2px)}.ganji-footer__cart-btn{position:relative;display:flex;align-items:center;justify-content:center;padding:var(--space-xs);background:transparent;border:none;cursor:pointer;color:var(--color-brand-400);transition:color .2s,transform .2s}.ganji-footer__cart-btn:hover{color:var(--color-brand-500);transform:translateY(-2px)}.ganji-footer__cart-badge{position:absolute;top:-2px;right:-2px;min-width:16px;height:16px;background:var(--color-brand-500);color:#fff;font-size:10px;font-weight:var(--font-semibold);line-height:1;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;padding:0 3px;pointer-events:none}.ganji-footer__content{padding:var(--space-2xl) 0;max-height:50vh;overflow-y:auto}.ganji-footer__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-xl)}.ganji-footer__section{display:flex;flex-direction:column;gap:var(--space-sm)}.ganji-footer__section-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-brand-500);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-xs)}.ganji-footer__brand-logo{width:auto;object-fit:contain;margin-bottom:var(--space-xs)}.ganji-footer__description{color:var(--color-brand-300);font-size:var(--text-sm);line-height:1.5}.ganji-footer__links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-xs)}.ganji-footer__link{color:var(--color-brand-300);font-size:var(--text-sm);text-decoration:none;transition:color var(--transition-fast)}.login-page{min-height:100%;display:flex;align-items:center;justify-content:center;padding:var(--space-md);background:var(--color-background)}.login-card{width:100%;max-width:26.25rem;text-align:center}.login-card__logo{font-size:var(--text-3xl);margin-bottom:var(--space-sm)}.login-card__title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-heading);margin-bottom:var(--space-xs)}.login-card__subtitle{color:var(--color-text-secondary);margin-bottom:var(--space-lg);font-size:var(--text-sm)}.login-card__social{display:flex;gap:var(--space-sm);margin-bottom:var(--space-md)}.social-button{flex:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);padding:var(--space-md) var(--space-sm);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base) var(--ease-in-out)}.social-button:hover:not(:disabled){background:var(--color-surface-muted);border-color:var(--color-brand-500);transform:translateY(-.125rem)}.social-button:disabled{opacity:.6;cursor:not-allowed}.social-button__icon{font-size:var(--text-lg)}.social-button__name{font-size:var(--text-xs);color:var(--color-text-secondary);font-weight:var(--font-medium)}.login-card__divider{display:flex;align-items:center;margin:var(--space-md) 0}.login-card__divider:before,.login-card__divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.login-card__divider span{padding:0 var(--space-md);color:var(--color-text-secondary);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em}.login-card__form{display:flex;flex-direction:column;gap:var(--space-md);text-align:left}.input-group{position:relative}.ganji-input{width:100%;padding:.75rem;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-primary);font-size:var(--text-base);transition:border-color var(--transition-fast),background-color var(--transition-fast)}.ganji-input:focus{outline:none;border-color:var(--color-brand-500)}.ganji-input:disabled{opacity:.6;cursor:not-allowed}.password-field{position:relative}.password-toggle{position:absolute;right:var(--space-sm);top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:var(--text-base);opacity:.6;padding:var(--space-xs);margin-top:var(--space-sm);transition:opacity var(--transition-fast) var(--ease-in-out)}.password-toggle:hover{opacity:1}.login-card__error{color:var(--color-error);font-size:var(--text-sm);text-align:center;padding:var(--space-sm);background:color-mix(in srgb,var(--color-error) 10%,transparent);border-radius:var(--radius-sm);margin:0}.login-card__success{color:var(--color-success);font-size:var(--text-sm);text-align:center;padding:var(--space-sm);background:color-mix(in srgb,var(--color-success) 10%,transparent);border-radius:var(--radius-sm);margin:0}.login-card__toggle{margin-top:var(--space-lg);font-size:var(--text-sm);color:var(--color-text-secondary)}.text-link{background:none;border:none;color:var(--color-brand-500);font-weight:var(--font-medium);cursor:pointer;text-decoration:underline;padding:0;font-size:inherit;transition:color var(--transition-fast) var(--ease-in-out)}.text-link:hover{color:var(--color-brand-400)}.login-card__terms{margin-top:var(--space-md);font-size:var(--text-xs);color:var(--color-text-secondary)}.login-card__terms a{color:var(--color-brand-500);text-decoration:underline;transition:color var(--transition-fast) var(--ease-in-out)}.login-card__terms a:hover{color:var(--color-brand-400)}@media(max-width:30rem){.login-card__social{flex-direction:column}.social-button{flex-direction:row;justify-content:center;padding:var(--space-sm) var(--space-md)}}.verify-email{min-height:calc(100vh - 10rem);display:flex;align-items:center;justify-content:center;padding:var(--space-xl) var(--space-lg)}.verify-email__card{width:100%;max-width:28rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-2xl);box-shadow:0 4px 24px #0000001a;text-align:center}.verify-email__icon{font-size:3rem;margin-bottom:var(--space-md)}.verify-email__title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-heading);margin:0 0 var(--space-md)}.verify-email__description{color:var(--color-text-secondary);font-size:var(--text-sm);margin-bottom:var(--space-xl);line-height:1.6}.verify-email__form{display:flex;flex-direction:column;gap:var(--space-md);text-align:left}.verify-email__form .ganji-input{text-align:center;letter-spacing:.2em;font-size:1.25rem}.verify-email__form input[type=email]{text-align:left;letter-spacing:normal;font-size:var(--text-base)}.verify-email__loading{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);padding:var(--space-xl) 0}.verify-email__loading p{color:var(--color-text-secondary)}.verify-email__success{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);padding:var(--space-xl) 0}.verify-email__success-icon{width:4rem;height:4rem;border-radius:50%;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;font-size:2rem;display:flex;align-items:center;justify-content:center}.verify-email__success p{color:#22c55e;font-weight:var(--font-medium)}.verify-email__redirect{color:var(--color-text-secondary)!important;font-size:var(--text-sm);font-weight:var(--font-normal)!important}.verify-email__error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-md)}.verify-email__error p{color:#ef4444;margin:0;font-size:var(--text-sm)}.verify-email__resend{margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid var(--color-border)}.verify-email__resend>p{color:var(--color-text-secondary);font-size:var(--text-sm);margin-bottom:var(--space-xs)}.verify-email__resend-btn{background:transparent;border:none;color:var(--color-brand-500);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;padding:0;transition:color var(--transition-fast)}.verify-email__resend-btn:hover{color:var(--color-brand-600);text-decoration:underline}.verify-email__resend-btn:disabled{opacity:.6;cursor:not-allowed}.verify-email__resend-message{margin-top:var(--space-sm);font-size:var(--text-xs)}.verify-email__resend-message--success{color:#22c55e}.verify-email__resend-message--error{color:#ef4444}.verify-email__footer{margin-top:var(--space-lg)}.verify-email__link{color:var(--color-text-secondary);font-size:var(--text-sm);text-decoration:none;transition:color var(--transition-fast)}.verify-email__link:hover{color:var(--color-brand-500)}.spinner{display:flex;align-items:center;justify-content:center}.spinner--sm{width:1.25rem;height:1.25rem}.spinner--md{width:2rem;height:2rem;padding:var(--space-md)}.spinner--lg{width:100%;min-height:200px}.spinner__circle{border:3px solid var(--color-border);border-top-color:var(--color-brand-500);border-radius:var(--radius-full);animation:spin .7s linear infinite}.spinner--sm .spinner__circle{width:1.25rem;height:1.25rem;border-width:2px}.spinner--md .spinner__circle{width:2rem;height:2rem}.spinner--lg .spinner__circle{width:3rem;height:3rem;border-width:4px}@keyframes spin{to{transform:rotate(360deg)}}.app{display:flex;flex-direction:column;min-height:100vh}.app__main{flex:1;max-width:1280px;width:100%;margin:0 auto;padding:var(--space-lg);padding-top:calc(5rem + var(--space-lg));margin-bottom:3.75rem;overflow-y:auto}
