:root{--color-primary:#ff7052;--color-primary-light:#ff8a70;--color-primary-dark:#e65a3d;--color-primary-rgb:255,112,82;--color-secondary:#2c3e50;--color-secondary-light:#3d5166;--color-secondary-dark:#1a252f;--color-accent:#f8d7cf;--color-accent-light:#fdf0ed;--color-gold:#d4af37;--color-white:#ffffff;--color-black:#000000;--color-gray-50:#fafafa;--color-gray-100:#f5f5f5;--color-gray-200:#eeeeee;--color-gray-300:#e0e0e0;--color-gray-400:#bdbdbd;--color-gray-500:#9e9e9e;--color-gray-600:#757575;--color-gray-700:#616161;--color-gray-800:#424242;--color-gray-900:#212121;--color-success:#4caf50;--color-warning:#ff9800;--color-error:#f44336;--color-info:#2196f3;--bg-primary:var(--color-white);--bg-secondary:var(--color-gray-50);--bg-tertiary:var(--color-accent-light);--bg-dark:var(--color-secondary);--text-primary:var(--color-gray-900);--text-secondary:var(--color-gray-600);--text-muted:var(--color-gray-500);--text-inverse:var(--color-white);--text-link:var(--color-primary);--font-display:'Playfair Display',Georgia,serif;--font-heading:'Amatic SC',cursive;--font-body:'Lora',Georgia,serif;--font-mono:'Fira Code',monospace;--font-admin:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;--text-xs:0.75rem;--text-sm:0.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--text-5xl:3rem;--text-6xl:3.75rem;--text-7xl:4.5rem;--font-light:300;--font-normal:400;--font-medium:500;--font-semibold:600;--font-bold:700;--leading-none:1;--leading-tight:1.25;--leading-snug:1.375;--leading-normal:1.5;--leading-relaxed:1.625;--leading-loose:2;--tracking-tighter:-0.05em;--tracking-tight:-0.025em;--tracking-normal:0;--tracking-wide:0.025em;--tracking-wider:0.05em;--tracking-widest:0.1em;--space-0:0;--space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--space-32:8rem;--rounded-none:0;--rounded-sm:0.125rem;--rounded:0.25rem;--rounded-md:0.375rem;--rounded-lg:0.5rem;--rounded-xl:0.75rem;--rounded-2xl:1rem;--rounded-3xl:1.5rem;--rounded-full:9999px;--shadow-sm:0 1px 2px 0 rgba(0,0,0,0.05);--shadow:0 1px 3px 0 rgba(0,0,0,0.1),0 1px 2px -1px rgba(0,0,0,0.1);--shadow-md:0 4px 6px -1px rgba(0,0,0,0.1),0 2px 4px -2px rgba(0,0,0,0.1);--shadow-lg:0 10px 15px -3px rgba(0,0,0,0.1),0 4px 6px -4px rgba(0,0,0,0.1);--shadow-xl:0 20px 25px -5px rgba(0,0,0,0.1),0 8px 10px -6px rgba(0,0,0,0.1);--shadow-2xl:0 25px 50px -12px rgba(0,0,0,0.25);--shadow-inner:inset 0 2px 4px 0 rgba(0,0,0,0.05);--shadow-primary:0 10px 30px -5px rgba(var(--color-primary-rgb),0.3);--transition-fast:150ms ease;--transition-base:300ms ease;--transition-slow:500ms ease;--transition-bounce:500ms cubic-bezier(0.68,-0.55,0.265,1.55);--z-dropdown:1000;--z-sticky:1020;--z-fixed:1030;--z-modal-backdrop:1040;--z-modal:1050;--z-popover:1060;--z-tooltip:1070;--z-notification:1080;--z-auth-modal:9000;--container-sm:640px;--container-md:768px;--container-lg:1024px;--container-xl:1280px;--container-2xl:1536px;--header-height:80px;--header-height-mobile:60px}
[data-theme="dark"]{--bg-primary:#1a1a2e;--bg-secondary:#16213e;--bg-tertiary:#0f3460;--bg-dark:#0a0a14;--text-primary:var(--color-gray-100);--text-secondary:#a3a3a3;--text-muted:#8b8b8b;--color-primary:#ff8a70;--color-primary-light:#ffa08a;--color-primary-dark:#ff7052;--color-primary-rgb:255,138,112;--color-gray-200:#374151;--color-gray-300:#4b5563;--color-gray-400:#9ca3af;--shadow-sm:0 1px 2px 0 rgba(0,0,0,0.3);--shadow:0 1px 3px 0 rgba(0,0,0,0.4),0 1px 2px -1px rgba(0,0,0,0.3);--shadow-md:0 4px 6px -1px rgba(0,0,0,0.4),0 2px 4px -2px rgba(0,0,0,0.3);--shadow-lg:0 10px 15px -3px rgba(0,0,0,0.4),0 4px 6px -4px rgba(0,0,0,0.3)}
*,*::before,*::after{box-sizing:border-box}
html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{margin:0;padding:0;font-family:var(--font-body);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--text-primary);background-color:var(--bg-primary);transition:background-color var(--transition-base),color var(--transition-base)}
h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:var(--font-bold);line-height:var(--leading-tight);margin-top:0;margin-bottom:var(--space-4);color:var(--text-primary)}
h1{font-size:var(--text-5xl)}
h2{font-size:var(--text-4xl)}
h3{font-size:var(--text-3xl)}
h4{font-size:var(--text-2xl)}
h5{font-size:var(--text-xl)}
h6{font-size:var(--text-lg)}
.display-heading{font-family:var(--font-heading);font-size:var(--text-7xl);font-weight:var(--font-bold);letter-spacing:var(--tracking-wide)}
p{margin-top:0;margin-bottom:var(--space-4)}
a{color:var(--text-link);text-decoration:none;transition:color var(--transition-fast)}
a:hover{color:var(--color-primary-dark)}
.container{width:100%;max-width:var(--container-xl);margin-left:auto;margin-right:auto;padding-left:var(--space-4);padding-right:var(--space-4)}
@media (min-width:768px){.container{padding-left:var(--space-6);padding-right:var(--space-6)}
}
.text-center{text-align:center}
.text-primary{color:var(--color-primary)}
.text-muted{color:var(--text-muted)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.hidden{display:none !important}
@media (max-width:767px){h1{font-size:var(--text-3xl)}
h2{font-size:var(--text-2xl)}
h3{font-size:var(--text-xl)}
.display-heading{font-size:var(--text-5xl)}
}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-family:var(--font-body);font-size:var(--text-base);font-weight:var(--font-medium);line-height:var(--leading-normal);text-decoration:none;border:2px solid transparent;border-radius:var(--rounded-lg);cursor:pointer;transition:all var(--transition-base);white-space:nowrap}
.btn:disabled{opacity:0.6;cursor:not-allowed}
.btn-primary{background-color:var(--color-primary);color:var(--color-white);border-color:var(--color-primary)}
.btn-primary:hover:not(:disabled){background-color:var(--color-primary-dark);border-color:var(--color-primary-dark);color:var(--color-white);transform:translateY(-2px);box-shadow:var(--shadow-primary)}
.btn-primary:active:not(:disabled){transform:translateY(0)}
.btn-secondary{background-color:transparent;color:var(--color-primary);border-color:var(--color-primary)}
.btn-secondary:hover:not(:disabled){background-color:var(--color-primary);color:var(--color-white)}
.btn-ghost{background-color:transparent;color:var(--text-primary);border-color:transparent}
.btn-ghost:hover:not(:disabled){background-color:var(--color-gray-100)}
[data-theme="dark"] .btn-ghost:hover:not(:disabled){background-color:var(--bg-tertiary)}
.btn-ghost-white{background-color:transparent;color:var(--color-white);border-color:rgba(255,255,255,0.3)}
.btn-ghost-white:hover:not(:disabled){background-color:rgba(255,255,255,0.2);border-color:rgba(255,255,255,0.5);color:var(--color-white)}
.btn-white{background-color:var(--color-white);color:var(--color-primary);border-color:var(--color-white)}
.btn-white:hover:not(:disabled){background-color:var(--color-gray-100);border-color:var(--color-gray-100);color:var(--color-primary)}
.btn-dark{background-color:var(--color-secondary);color:var(--color-white);border-color:var(--color-secondary)}
.btn-dark:hover:not(:disabled){background-color:var(--color-secondary-dark);border-color:var(--color-secondary-dark);color:var(--color-white)}
.btn-sm{padding:var(--space-2) var(--space-4);font-size:var(--text-sm)}
.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--text-lg)}
.btn-xl{padding:var(--space-5) var(--space-10);font-size:var(--text-xl)}
.btn-block{display:flex;width:100%}
.btn-icon{padding:var(--space-3);border-radius:var(--rounded-full)}
.btn-icon svg{width:1.25rem;height:1.25rem}
.btn-group{display:flex;gap:var(--space-2);flex-wrap:wrap}
.btn-group-vertical{flex-direction:column}
.btn-loading{position:relative;color:transparent !important}
.btn-loading::after{content:'';position:absolute;width:1rem;height:1rem;border:2px solid currentColor;border-right-color:transparent;border-radius:var(--rounded-full);animation:btn-spin 0.75s linear infinite}
@keyframes btn-spin{to{transform:rotate(360deg)}
}
.btn-link{padding:0;background:none;border:none;color:var(--color-primary);font-weight:var(--font-normal);text-decoration:underline}
.btn-link:hover{color:var(--color-primary-dark)}
.card{background-color:var(--bg-primary);border-radius:var(--rounded-xl);box-shadow:var(--shadow-md);overflow:hidden;transition:transform var(--transition-base),box-shadow var(--transition-base)}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.card-image{position:relative;overflow:hidden;aspect-ratio:4/3}
.card-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}
.card:hover .card-image img{transform:scale(1.05)}
.card-badge{position:absolute;top:var(--space-3);right:var(--space-3);padding:var(--space-1) var(--space-3);background-color:var(--color-primary);color:var(--color-white);font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:var(--tracking-wide);border-radius:var(--rounded-full)}
.card-badge-gold{background-color:var(--color-gold)}
.card-content{padding:var(--space-6)}
.card-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);margin-bottom:var(--space-2);color:var(--text-primary)}
.card-description{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-4);line-height:var(--leading-relaxed)}
.card-price{display:flex;align-items:baseline;gap:var(--space-1);margin-bottom:var(--space-4)}
.card-price-amount{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--color-primary)}
.card-price-currency{font-size:var(--text-lg);color:var(--text-secondary)}
.card-features{list-style:none;padding:0;margin:0 0 var(--space-4) 0}
.card-features li{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) 0;font-size:var(--text-sm);color:var(--text-secondary)}
.card-features li::before{content:'';width:1rem;height:1rem;background-color:var(--color-primary);mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='currentColor'%3E%3Cpath fill-rule='evenodd' d='M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z' clip-rule='evenodd'/%3E%3C/svg%3E");mask-size:contain;flex-shrink:0}
.card-footer{padding:var(--space-4) var(--space-6);background-color:var(--bg-secondary);border-top:1px solid var(--color-gray-200)}
[data-theme="dark"] .card-footer{border-top-color:var(--bg-tertiary)}
.product-card{position:relative}
.product-card.is-premium{border:2px solid var(--color-gold)}
.product-card.is-premium::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--color-gold),#f5e6a3,var(--color-gold))}
.gallery-card{cursor:pointer}
.gallery-card .card-image{aspect-ratio:1}
.gallery-card .card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,0.6) 0%,transparent 50%);opacity:0;transition:opacity var(--transition-base);display:flex;align-items:flex-end;padding:var(--space-4)}
.gallery-card:hover .card-overlay{opacity:1}
.gallery-card .card-overlay-title{color:var(--color-white);font-size:var(--text-sm);font-weight:var(--font-medium)}
.addon-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);border:1px solid var(--color-gray-200);border-radius:var(--rounded-lg);cursor:pointer;transition:all var(--transition-base)}
.addon-card:hover{border-color:var(--color-primary);transform:none;box-shadow:none}
.addon-card.is-selected{border-color:var(--color-primary);background-color:var(--color-accent-light)}
.addon-card-icon{width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;background-color:var(--color-accent);border-radius:var(--rounded-full);color:var(--color-primary)}
.addon-card-content{flex:1}
.addon-card-title{font-weight:var(--font-semibold);margin-bottom:var(--space-1)}
.addon-card-price{font-size:var(--text-sm);color:var(--color-primary);font-weight:var(--font-bold)}
.addon-card-checkbox{width:1.5rem;height:1.5rem;border:2px solid var(--color-gray-300);border-radius:var(--rounded);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}
.addon-card.is-selected .addon-card-checkbox{background-color:var(--color-primary);border-color:var(--color-primary)}
.addon-card.is-selected .addon-card-checkbox::after{content:'';width:0.75rem;height:0.75rem;background-color:var(--color-white);mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='currentColor'%3E%3Cpath fill-rule='evenodd' d='M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z' clip-rule='evenodd'/%3E%3C/svg%3E");mask-size:contain}
[data-theme="dark"] .addon-card{border-color:var(--bg-tertiary)}
[data-theme="dark"] .addon-card.is-selected{background-color:var(--bg-tertiary)}
.form-group{margin-bottom:var(--space-6)}
.form-label{display:block;margin-bottom:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary)}
.form-label-required::after{content:' *';color:var(--color-error)}
.form-input,.form-select,.form-textarea{display:block;width:100%;padding:var(--space-3) var(--space-4);font-family:var(--font-body);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--text-primary);background-color:var(--bg-primary);border:2px solid var(--color-gray-300);border-radius:var(--rounded-lg);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}
.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),0.2)}
.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}
.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background-color:var(--color-gray-100);cursor:not-allowed;opacity:0.6}
.form-input.is-invalid,.form-select.is-invalid,.form-textarea.is-invalid{border-color:var(--color-error)}
.form-input.is-invalid:focus,.form-select.is-invalid:focus,.form-textarea.is-invalid:focus{box-shadow:0 0 0 3px rgba(244,67,54,0.2)}
.form-input.is-valid,.form-select.is-valid,.form-textarea.is-valid{border-color:var(--color-success)}
.form-error,.field-error{display:block;margin-top:var(--space-1);font-size:var(--text-sm);color:var(--color-error);animation:field-error-appear 0.2s ease-out}
.field-error:empty{display:none}
@keyframes field-error-appear{from{opacity:0;transform:translateY(-4px)}
to{opacity:1;transform:translateY(0)}
}
.form-hint{display:block;margin-top:var(--space-1);font-size:var(--text-sm);color:var(--text-muted)}
.form-input.is-valid,.form-select.is-valid,.form-textarea.is-valid{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2310b981' stroke-width='2'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 0.75rem center;background-size:1rem;padding-right:2.5rem}
.form-input.is-invalid,.form-select.is-invalid,.form-textarea.is-invalid{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23ef4444' stroke-width='2'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cline x1='15' y1='9' x2='9' y2='15'/%3E%3Cline x1='9' y1='9' x2='15' y2='15'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 0.75rem center;background-size:1rem;padding-right:2.5rem}
.form-textarea{min-height:120px;resize:vertical}
.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236B7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E");background-position:right var(--space-3) center;background-repeat:no-repeat;background-size:1.25rem;padding-right:var(--space-10)}
.form-check{display:flex;align-items:flex-start;gap:var(--space-3);cursor:pointer}
.form-check-input{flex-shrink:0;width:1.25rem;height:1.25rem;margin-top:0.125rem;appearance:none;background-color:var(--bg-primary);border:2px solid var(--color-gray-300);transition:all var(--transition-fast);cursor:pointer}
.form-check-input[type="checkbox"]{border-radius:var(--rounded)}
.form-check-input[type="radio"]{border-radius:var(--rounded-full)}
.form-check-input:checked{background-color:var(--color-primary);border-color:var(--color-primary)}
.form-check-input[type="checkbox"]:checked{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='white'%3E%3Cpath fill-rule='evenodd' d='M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z' clip-rule='evenodd'/%3E%3C/svg%3E");background-size:100%}
.form-check-input[type="radio"]:checked{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Ccircle cx='10' cy='10' r='5' fill='white'/%3E%3C/svg%3E");background-size:100%}
.form-check-input:focus{outline:none;box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),0.2)}
.form-check-label{font-size:var(--text-sm);color:var(--text-primary)}
.form-input-icon{position:relative}
.form-input-icon .form-input{padding-left:var(--space-10)}
.form-input-icon-left{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}
.form-input-icon-left svg{width:1.25rem;height:1.25rem}
.form-date{position:relative}
.form-date input[type="date"]{cursor:pointer}
.form-price{position:relative}
.form-price .form-input{padding-left:var(--space-8)}
.form-price-symbol{position:absolute;left:var(--space-4);top:50%;transform:translateY(-50%);color:var(--text-muted);font-weight:var(--font-medium)}
.form-row{display:grid;gap:var(--space-4)}
@media (min-width:640px){.form-row-2{grid-template-columns:repeat(2,1fr)}
.form-row-3{grid-template-columns:repeat(3,1fr)}
}
[data-theme="dark"] .form-input,[data-theme="dark"] .form-select,[data-theme="dark"] .form-textarea{background-color:var(--bg-secondary);border-color:var(--bg-tertiary)}
[data-theme="dark"] .form-input:disabled,[data-theme="dark"] .form-select:disabled,[data-theme="dark"] .form-textarea:disabled{background-color:var(--bg-tertiary)}
[data-theme="dark"] .form-check-input{background-color:var(--bg-secondary);border-color:var(--bg-tertiary)}
.header{position:fixed;top:0;left:0;right:0;height:var(--header-height);background-color:var(--bg-primary);border-bottom:1px solid var(--color-gray-200);z-index:var(--z-sticky);transition:all var(--transition-base)}
.header.is-scrolled{box-shadow:var(--shadow-md)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:100%;max-width:var(--container-xl);margin:0 auto;padding:0 var(--space-4)}
.header-logo{display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);text-decoration:none}
.header-logo img{height:40px;width:auto}
.header-logo-text{display:none}
@media (min-width:640px){.header-logo-text{display:block}
}
.nav{display:none}
@media (min-width:1024px){.nav{display:flex;align-items:center;gap:var(--space-1)}
}
.nav-link{display:flex;align-items:center;padding:var(--space-2) var(--space-4);font-size:var(--text-base);font-weight:var(--font-medium);color:var(--text-secondary);text-decoration:none;border-radius:var(--rounded-lg);transition:all var(--transition-fast)}
.nav-link:hover{color:var(--color-primary);background-color:var(--color-accent-light)}
.nav-link.is-active{color:var(--color-primary)}
.header-actions{display:flex;align-items:center;gap:var(--space-2)}
.lang-switcher{position:relative}
.lang-switcher-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);background:none;border:none;font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;border-radius:var(--rounded-lg);transition:all var(--transition-fast)}
.lang-switcher-btn:hover{background-color:var(--color-gray-100)}
.lang-switcher-dropdown{position:absolute;top:100%;right:0;margin-top:var(--space-2);min-width:160px;background-color:var(--bg-primary);border:1px solid var(--color-gray-200);border-radius:var(--rounded-lg);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(-10px);transition:all var(--transition-fast);z-index:var(--z-dropdown)}
.lang-switcher.is-open .lang-switcher-dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.lang-switcher-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);color:var(--text-primary);text-decoration:none;transition:background-color var(--transition-fast)}
.lang-switcher-item:hover{background-color:var(--color-gray-100)}
.lang-switcher-item.is-active{color:var(--color-primary);background-color:var(--color-accent-light)}
.theme-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:none;border:none;color:var(--text-secondary);cursor:pointer;border-radius:var(--rounded-lg);transition:all var(--transition-fast)}
.theme-toggle:hover{background-color:var(--color-gray-100);color:var(--color-primary)}
.theme-toggle svg{width:1.25rem;height:1.25rem}
.theme-toggle .icon-sun{display:none}
.theme-toggle .icon-moon{display:block}
[data-theme="dark"] .theme-toggle .icon-sun{display:block}
[data-theme="dark"] .theme-toggle .icon-moon{display:none}
.mobile-menu-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:none;border:none;color:var(--text-primary);cursor:pointer;border-radius:var(--rounded-lg)}
@media (min-width:1024px){.mobile-menu-toggle{display:none}
}
.mobile-menu-toggle svg{width:1.5rem;height:1.5rem}
.mobile-nav{position:fixed;top:var(--header-height);left:0;right:0;bottom:0;background-color:var(--bg-primary);padding:var(--space-4);transform:translateX(100%);transition:transform var(--transition-base);z-index:var(--z-fixed);overflow-y:auto}
.mobile-nav.is-open{transform:translateX(0)}
@media (min-width:1024px){.mobile-nav{display:none}
}
.mobile-nav-link{display:block;padding:var(--space-4);font-size:var(--text-lg);font-weight:var(--font-medium);color:var(--text-primary);text-decoration:none;border-bottom:1px solid var(--color-gray-200)}
.mobile-nav-link:hover{color:var(--color-primary)}
.footer{background-color:var(--color-secondary);color:var(--color-white);padding:var(--space-16) 0 var(--space-8)}
.footer-grid{display:grid;gap:var(--space-8);margin-bottom:var(--space-12)}
@media (min-width:768px){.footer-grid{grid-template-columns:repeat(2,1fr)}
}
@media (min-width:1024px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr}
}
.footer-brand{max-width:320px}
.footer-logo{display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-heading);font-size:var(--text-2xl);color:var(--color-white);text-decoration:none;margin-bottom:var(--space-4)}
.footer-description{font-size:var(--text-sm);color:var(--color-gray-400);line-height:var(--leading-relaxed)}
.footer-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-bold);margin-bottom:var(--space-4)}
.footer-links{list-style:none;padding:0;margin:0}
.footer-links li{margin-bottom:var(--space-2)}
.footer-links a{font-size:var(--text-sm);color:var(--color-gray-400);text-decoration:none;transition:color var(--transition-fast)}
.footer-links a:hover{color:var(--color-white)}
.footer-social{display:flex;gap:var(--space-3);margin-top:var(--space-4)}
.footer-social a{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background-color:var(--color-secondary-light);color:var(--color-white);border-radius:var(--rounded-full);transition:all var(--transition-fast)}
.footer-social a:hover{background-color:var(--color-primary)}
.footer-bottom{padding-top:var(--space-8);border-top:1px solid var(--color-secondary-light);display:flex;flex-direction:column;gap:var(--space-4);align-items:center;text-align:center}
@media (min-width:768px){.footer-bottom{flex-direction:row;justify-content:space-between;text-align:left}
}
.footer-copyright{font-size:var(--text-sm);color:var(--color-gray-500)}
.footer-legal{display:flex;gap:var(--space-4)}
.footer-legal a{font-size:var(--text-sm);color:var(--color-gray-500);text-decoration:none}
.footer-legal a:hover{color:var(--color-white)}
[data-theme="dark"] .header{background-color:var(--bg-primary);border-bottom-color:var(--bg-tertiary)}
[data-theme="dark"] .lang-switcher-dropdown{background-color:var(--bg-secondary);border-color:var(--bg-tertiary)}
[data-theme="dark"] .lang-switcher-item:hover,[data-theme="dark"] .theme-toggle:hover,[data-theme="dark"] .lang-switcher-btn:hover{background-color:var(--bg-tertiary)}
[data-theme="dark"] .mobile-nav-link{border-bottom-color:var(--bg-tertiary)}
.user-login-btn{display:flex;align-items:center;gap:var(--space-2)}
.user-login-btn svg{flex-shrink:0}
.user-menu{position:relative}
.user-menu-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);background:none;border:1px solid var(--color-gray-200);font-size:var(--text-sm);font-family:var(--font-body);color:var(--text-primary);cursor:pointer;border-radius:var(--rounded-full);transition:all var(--transition-fast)}
.user-menu-btn:hover{background-color:var(--color-gray-50);border-color:var(--color-gray-300)}
.user-menu-avatar{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:white;font-weight:var(--font-semibold);font-size:var(--text-sm);text-transform:uppercase;border-radius:var(--rounded-full)}
.user-menu-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:var(--font-medium)}
.user-menu-btn svg{flex-shrink:0;color:var(--text-muted);transition:transform var(--transition-fast)}
.user-menu.is-open .user-menu-btn svg:last-child{transform:rotate(180deg)}
.user-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:220px;background-color:var(--bg-primary);border:1px solid var(--color-gray-200);border-radius:var(--rounded-xl);box-shadow:var(--shadow-xl);opacity:0;visibility:hidden;transform:translateY(-10px) scale(0.95);transition:all var(--transition-fast);z-index:var(--z-dropdown);overflow:hidden}
.user-menu.is-open .user-menu-dropdown{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
.user-menu-header{padding:var(--space-3) var(--space-4);background-color:var(--color-gray-50);border-bottom:1px solid var(--color-gray-200)}
.user-menu-email{font-size:var(--text-xs);color:var(--text-muted);display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-menu-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--text-primary);text-decoration:none;transition:all var(--transition-fast)}
.user-menu-item svg{flex-shrink:0;color:var(--text-muted)}
.user-menu-item:hover{background-color:var(--color-accent-light);color:var(--color-primary)}
.user-menu-item:hover svg{color:var(--color-primary)}
.user-menu-item--danger{color:var(--color-error)}
.user-menu-item--danger svg{color:var(--color-error)}
.user-menu-item--danger:hover{background-color:#ffebee;color:var(--color-error)}
.user-menu-divider{height:1px;background-color:var(--color-gray-200);margin:var(--space-2) 0}
[data-theme="dark"] .user-menu-btn{border-color:var(--bg-tertiary)}
[data-theme="dark"] .user-menu-btn:hover{background-color:var(--bg-tertiary);border-color:var(--bg-tertiary)}
[data-theme="dark"] .user-menu-dropdown{background-color:var(--bg-secondary);border-color:var(--bg-tertiary)}
[data-theme="dark"] .user-menu-header{background-color:var(--bg-tertiary);border-color:var(--bg-tertiary)}
[data-theme="dark"] .user-menu-item:hover{background-color:var(--bg-tertiary)}
[data-theme="dark"] .user-menu-divider{background-color:var(--bg-tertiary)}
[data-theme="dark"] .user-menu-item--danger:hover{background-color:rgba(244,67,54,0.15)}
.faq-hero{position:relative;padding:var(--space-20) 0 var(--space-16);background:linear-gradient(135deg,var(--color-accent-light) 0%,var(--bg-primary) 50%,var(--color-accent-light) 100%);text-align:center;overflow:hidden}
.faq-hero::before{content:'';position:absolute;top:-100px;right:-100px;width:300px;height:300px;background:radial-gradient(circle,rgba(var(--color-primary-rgb),0.08) 0%,transparent 70%);border-radius:var(--rounded-full);animation:floatSlow 8s ease-in-out infinite}
.faq-hero::after{content:'';position:absolute;bottom:-50px;left:-50px;width:200px;height:200px;background:radial-gradient(circle,rgba(var(--color-primary-rgb),0.06) 0%,transparent 70%);border-radius:var(--rounded-full);animation:floatSlow 10s ease-in-out infinite reverse}
@keyframes floatSlow{0%,100%{transform:translate(0,0) scale(1)}
50%{transform:translate(20px,-20px) scale(1.1)}
}
.faq-hero-decoration{position:absolute;opacity:0.4;pointer-events:none}
.faq-hero-decoration--1{top:20%;left:10%;width:60px;height:60px;border:2px solid var(--color-primary);border-radius:var(--rounded-full);animation:rotate 20s linear infinite}
.faq-hero-decoration--2{top:30%;right:15%;width:40px;height:40px;background:var(--color-accent);transform:rotate(45deg);animation:pulse 4s ease-in-out infinite}
.faq-hero-decoration--3{bottom:25%;left:20%;width:8px;height:8px;background:var(--color-primary);border-radius:var(--rounded-full);animation:pulse 3s ease-in-out infinite 0.5s}
.faq-hero-decoration--4{bottom:35%;right:25%;width:12px;height:12px;background:var(--color-accent);border-radius:var(--rounded-full);animation:pulse 3.5s ease-in-out infinite 1s}
@keyframes rotate{from{transform:rotate(0deg)}
to{transform:rotate(360deg)}
}
@keyframes pulse{0%,100%{opacity:0.4;transform:scale(1)}
50%{opacity:0.7;transform:scale(1.2)}
}
.faq-hero-content{position:relative;z-index:1}
.faq-hero-title{font-family:var(--font-heading);font-size:var(--text-6xl);margin-bottom:var(--space-4);color:var(--text-primary);animation:fadeSlideUp 0.8s ease-out forwards;opacity:0}
.faq-hero-subtitle{font-size:var(--text-xl);color:var(--text-secondary);max-width:600px;margin:0 auto;line-height:var(--leading-relaxed);animation:fadeSlideUp 0.8s ease-out 0.2s forwards;opacity:0}
@keyframes fadeSlideUp{from{opacity:0;transform:translateY(30px)}
to{opacity:1;transform:translateY(0)}
}
.faq-search{max-width:500px;margin:var(--space-8) auto 0;position:relative;animation:fadeSlideUp 0.8s ease-out 0.4s forwards;opacity:0}
.faq-search-input{width:100%;padding:var(--space-4) var(--space-6);padding-left:var(--space-12);font-family:var(--font-body);font-size:var(--text-base);background:var(--bg-primary);border:2px solid var(--color-gray-200);border-radius:var(--rounded-full);box-shadow:var(--shadow-md);transition:all var(--transition-base)}
.faq-search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-lg),0 0 0 4px rgba(var(--color-primary-rgb),0.1)}
.faq-search-icon{position:absolute;left:var(--space-4);top:50%;transform:translateY(-50%);width:24px;height:24px;color:var(--text-muted)}
.faq-categories{padding:var(--space-12) 0;background:var(--bg-secondary)}
.faq-categories-grid{display:grid;grid-template-columns:repeat(1,1fr);gap:var(--space-6);max-width:1000px;margin:0 auto}
@media (min-width:640px){.faq-categories-grid{grid-template-columns:repeat(3,1fr)}
}
.faq-category-card{background:var(--bg-primary);border-radius:var(--rounded-xl);padding:var(--space-8);text-align:center;box-shadow:var(--shadow-md);transition:all var(--transition-base);cursor:pointer;border:2px solid transparent;opacity:0;transform:translateY(20px)}
.faq-category-card.is-visible{animation:fadeSlideUp 0.6s ease-out forwards}
.faq-category-card:nth-child(1).is-visible{animation-delay:0.1s}
.faq-category-card:nth-child(2).is-visible{animation-delay:0.2s}
.faq-category-card:nth-child(3).is-visible{animation-delay:0.3s}
.faq-category-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl);border-color:var(--color-primary)}
.faq-category-card.is-active{border-color:var(--color-primary);background:var(--color-accent-light)}
.faq-category-icon{width:72px;height:72px;margin:0 auto var(--space-4);display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-accent-light) 100%);border-radius:var(--rounded-2xl);color:var(--color-primary);transition:all var(--transition-base)}
.faq-category-card:hover .faq-category-icon{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);color:var(--color-white);transform:scale(1.1)}
.faq-category-icon svg{width:36px;height:36px}
.faq-category-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);margin-bottom:var(--space-2);color:var(--text-primary)}
.faq-category-count{font-size:var(--text-sm);color:var(--text-muted)}
.faq-content{padding:var(--space-16) 0}
.faq-section{max-width:800px;margin:0 auto var(--space-12)}
.faq-section:last-child{margin-bottom:0}
.faq-section-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:2px solid var(--color-gray-200)}
.faq-section-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-accent);border-radius:var(--rounded-xl);color:var(--color-primary);flex-shrink:0}
.faq-section-icon svg{width:24px;height:24px}
.faq-section-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);margin:0}
.faq-accordion{display:flex;flex-direction:column;gap:var(--space-4)}
.faq-item{background:var(--bg-primary);border-radius:var(--rounded-xl);box-shadow:var(--shadow);overflow:hidden;transition:all var(--transition-base);border:1px solid var(--color-gray-200);opacity:0;transform:translateY(20px)}
.faq-item.is-visible{animation:fadeSlideUp 0.5s ease-out forwards}
.faq-item:nth-child(1).is-visible{animation-delay:0.05s}
.faq-item:nth-child(2).is-visible{animation-delay:0.1s}
.faq-item:nth-child(3).is-visible{animation-delay:0.15s}
.faq-item:nth-child(4).is-visible{animation-delay:0.2s}
.faq-item:nth-child(5).is-visible{animation-delay:0.25s}
.faq-item:nth-child(6).is-visible{animation-delay:0.3s}
.faq-item:nth-child(7).is-visible{animation-delay:0.35s}
.faq-item:nth-child(8).is-visible{animation-delay:0.4s}
.faq-item:nth-child(9).is-visible{animation-delay:0.45s}
.faq-item:nth-child(10).is-visible{animation-delay:0.5s}
.faq-item:hover{box-shadow:var(--shadow-md);border-color:var(--color-gray-300)}
.faq-item.is-open{box-shadow:var(--shadow-lg);border-color:var(--color-primary)}
.faq-question{display:flex;align-items:center;gap:var(--space-4);width:100%;padding:var(--space-5) var(--space-6);background:none;border:none;font-family:var(--font-body);font-size:var(--text-base);font-weight:var(--font-medium);text-align:left;color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast)}
.faq-question:hover{background:var(--color-gray-50)}
.faq-item.is-open .faq-question{background:var(--color-accent-light)}
.faq-number{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--color-gray-100);border-radius:var(--rounded-lg);font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--text-muted);transition:all var(--transition-base)}
.faq-item.is-open .faq-number{background:var(--color-primary);color:var(--color-white)}
.faq-question-text{flex:1;line-height:var(--leading-snug)}
.faq-toggle-icon{flex-shrink:0;width:24px;height:24px;color:var(--text-muted);transition:all var(--transition-base)}
.faq-item.is-open .faq-toggle-icon{transform:rotate(180deg);color:var(--color-primary)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height var(--transition-base) ease-out}
.faq-item.is-open .faq-answer{max-height:500px}
.faq-answer-content{padding:0 var(--space-6) var(--space-6);padding-left:calc(var(--space-6) + 32px + var(--space-4));font-size:var(--text-base);color:var(--text-secondary);line-height:var(--leading-relaxed)}
.faq-answer-content p{margin:0}
.faq-answer-content ul{margin:var(--space-3) 0;padding-left:var(--space-6)}
.faq-answer-content li{margin-bottom:var(--space-2)}
.faq-cta{position:relative;padding:var(--space-16) 0;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);overflow:hidden}
.faq-cta::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle at 20% 80%,rgba(255,255,255,0.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(255,255,255,0.1) 0%,transparent 50%),url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");pointer-events:none}
.faq-cta-decoration{position:absolute;border-radius:var(--rounded-full);background:rgba(255,255,255,0.1);pointer-events:none}
.faq-cta-decoration--1{width:200px;height:200px;top:-50px;right:-50px;animation:floatSlow 12s ease-in-out infinite}
.faq-cta-decoration--2{width:150px;height:150px;bottom:-30px;left:10%;animation:floatSlow 10s ease-in-out infinite reverse}
.faq-cta-decoration--3{width:100px;height:100px;top:30%;left:-30px;animation:floatSlow 8s ease-in-out infinite 2s}
.faq-cta-content{position:relative;z-index:1;text-align:center;max-width:600px;margin:0 auto}
.faq-cta-icon{width:80px;height:80px;margin:0 auto var(--space-6);display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.2);border-radius:var(--rounded-full);color:var(--color-white)}
.faq-cta-icon svg{width:40px;height:40px}
.faq-cta-title{font-family:var(--font-heading);font-size:var(--text-4xl);font-weight:var(--font-bold);color:var(--color-white);margin-bottom:var(--space-4)}
.faq-cta-text{font-size:var(--text-lg);color:rgba(255,255,255,0.9);margin-bottom:var(--space-8);line-height:var(--leading-relaxed)}
.faq-cta-buttons{display:flex;flex-direction:column;gap:var(--space-4);justify-content:center;align-items:center}
@media (min-width:640px){.faq-cta-buttons{flex-direction:row}
}
.faq-cta .btn-white{background:var(--color-white);color:var(--color-primary);padding:var(--space-4) var(--space-8);font-weight:var(--font-semibold);border-radius:var(--rounded-full);transition:all var(--transition-base);box-shadow:var(--shadow-lg)}
.faq-cta .btn-white:hover{transform:translateY(-2px);box-shadow:var(--shadow-xl);background:var(--color-white);color:var(--color-primary-dark)}
.faq-cta .btn-outline-white{background:transparent;color:var(--color-white);padding:var(--space-4) var(--space-8);font-weight:var(--font-semibold);border:2px solid rgba(255,255,255,0.5);border-radius:var(--rounded-full);transition:all var(--transition-base)}
.faq-cta .btn-outline-white:hover{background:rgba(255,255,255,0.1);border-color:var(--color-white);color:var(--color-white)}
.faq-empty{text-align:center;padding:var(--space-16) var(--space-4)}
.faq-empty-icon{width:80px;height:80px;margin:0 auto var(--space-6);display:flex;align-items:center;justify-content:center;background:var(--color-gray-100);border-radius:var(--rounded-full);color:var(--text-muted)}
.faq-empty-icon svg{width:40px;height:40px}
.faq-empty-title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-2)}
.faq-empty-text{color:var(--text-muted)}
[data-theme="dark"] .faq-hero{background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-primary) 50%,var(--bg-tertiary) 100%)}
[data-theme="dark"] .faq-hero::before,[data-theme="dark"] .faq-hero::after{background:radial-gradient(circle,rgba(var(--color-primary-rgb),0.15) 0%,transparent 70%)}
[data-theme="dark"] .faq-hero-decoration--1{border-color:var(--color-primary-light)}
[data-theme="dark"] .faq-hero-decoration--2{background:var(--bg-tertiary)}
[data-theme="dark"] .faq-search-input{background:var(--bg-secondary);border-color:var(--bg-tertiary);color:var(--text-primary)}
[data-theme="dark"] .faq-categories{background:var(--bg-secondary)}
[data-theme="dark"] .faq-category-card{background:var(--bg-primary)}
[data-theme="dark"] .faq-category-card.is-active{background:var(--bg-tertiary)}
[data-theme="dark"] .faq-category-icon{background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-secondary) 100%)}
[data-theme="dark"] .faq-section-header{border-bottom-color:var(--bg-tertiary)}
[data-theme="dark"] .faq-section-icon{background:var(--bg-tertiary)}
[data-theme="dark"] .faq-item{background:var(--bg-primary);border-color:var(--bg-tertiary)}
[data-theme="dark"] .faq-item:hover{border-color:var(--bg-tertiary)}
[data-theme="dark"] .faq-item.is-open{border-color:var(--color-primary)}
[data-theme="dark"] .faq-question:hover{background:var(--bg-secondary)}
[data-theme="dark"] .faq-item.is-open .faq-question{background:var(--bg-tertiary)}
[data-theme="dark"] .faq-number{background:var(--bg-tertiary)}
[data-theme="dark"] .faq-empty-icon{background:var(--bg-tertiary)}
@media (max-width:767px){.faq-hero{padding:var(--space-12) 0}
.faq-hero-title{font-size:var(--text-4xl)}
.faq-hero-subtitle{font-size:var(--text-base);padding:0 var(--space-4)}
.faq-hero-decoration{display:none}
.faq-categories{padding:var(--space-8) 0}
.faq-category-card{padding:var(--space-6)}
.faq-category-icon{width:56px;height:56px}
.faq-category-icon svg{width:28px;height:28px}
.faq-content{padding:var(--space-10) 0}
.faq-section-header{flex-direction:column;text-align:center}
.faq-question{padding:var(--space-4);gap:var(--space-3)}
.faq-number{width:28px;height:28px;font-size:var(--text-xs)}
.faq-answer-content{padding:0 var(--space-4) var(--space-4);padding-left:calc(var(--space-4) + 28px + var(--space-3));font-size:var(--text-sm)}
.faq-cta{padding:var(--space-12) 0}
.faq-cta-title{font-size:var(--text-3xl)}
.faq-cta-text{font-size:var(--text-base)}
.faq-cta-icon{width:64px;height:64px}
.faq-cta-icon svg{width:32px;height:32px}
.faq-cta-decoration{opacity:0.5}
}
@media (min-width:768px) and (max-width:1023px){.faq-hero-title{font-size:var(--text-5xl)}
.faq-category-card{padding:var(--space-6)}
}
.page-hero{position:relative;padding:var(--space-20) 0 var(--space-16);text-align:center;overflow:hidden}
.page-hero-content{position:relative;z-index:1}
.page-hero-title{font-family:var(--font-heading);font-size:var(--text-6xl);margin-bottom:var(--space-4);color:var(--text-primary);animation:heroFadeSlideUp 0.8s ease-out forwards;opacity:0}
.page-hero-subtitle{font-size:var(--text-xl);color:var(--text-secondary);max-width:600px;margin:0 auto;line-height:var(--leading-relaxed);animation:heroFadeSlideUp 0.8s ease-out 0.2s forwards;opacity:0}
@keyframes heroFadeSlideUp{from{opacity:0;transform:translateY(30px)}
to{opacity:1;transform:translateY(0)}
}
.page-hero-decoration{position:absolute;opacity:0.4;pointer-events:none}
.about-hero{background:linear-gradient(135deg,#fff5f3 0%,var(--bg-primary) 40%,#fdf0ed 100%)}
.about-hero::before{content:'';position:absolute;top:-80px;right:-80px;width:350px;height:350px;background:radial-gradient(circle,rgba(248,215,207,0.5) 0%,transparent 70%);border-radius:var(--rounded-full);animation:aboutFloat 10s ease-in-out infinite}
.about-hero::after{content:'';position:absolute;bottom:-60px;left:-60px;width:280px;height:280px;background:radial-gradient(circle,rgba(var(--color-primary-rgb),0.08) 0%,transparent 70%);border-radius:var(--rounded-full);animation:aboutFloat 12s ease-in-out infinite reverse}
@keyframes aboutFloat{0%,100%{transform:translate(0,0) scale(1)}
50%{transform:translate(15px,-15px) scale(1.05)}
}
.about-hero-decoration--heart-1{top:15%;left:8%;width:40px;height:40px;animation:heartPulse 3s ease-in-out infinite}
.about-hero-decoration--heart-1::before,.about-hero-decoration--heart-1::after{content:'';position:absolute;width:20px;height:32px;background:var(--color-accent);border-radius:20px 20px 0 0}
.about-hero-decoration--heart-1::before{left:0;transform:rotate(-45deg);transform-origin:0 100%}
.about-hero-decoration--heart-1::after{right:0;transform:rotate(45deg);transform-origin:100% 100%}
.about-hero-decoration--heart-2{top:25%;right:12%;width:30px;height:30px;animation:heartPulse 4s ease-in-out infinite 0.5s}
.about-hero-decoration--heart-2::before,.about-hero-decoration--heart-2::after{content:'';position:absolute;width:15px;height:24px;background:var(--color-primary);opacity:0.3;border-radius:15px 15px 0 0}
.about-hero-decoration--heart-2::before{left:0;transform:rotate(-45deg);transform-origin:0 100%}
.about-hero-decoration--heart-2::after{right:0;transform:rotate(45deg);transform-origin:100% 100%}
.about-hero-decoration--wave{bottom:0;left:0;right:0;height:60px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 120' preserveAspectRatio='none'%3E%3Cpath d='M321.39,56.44c58-10.79,114.16-30.13,172-41.86,82.39-16.72,168.19-17.73,250.45-.39C823.78,31,906.67,72,985.66,92.83c70.05,18.48,146.53,26.09,214.34,3V0H0V27.35A600.21,600.21,0,0,0,321.39,56.44Z' fill='%23f8d7cf' opacity='0.3'/%3E%3C/svg%3E") no-repeat bottom center;background-size:cover;opacity:1}
.about-hero-decoration--circle-1{bottom:30%;left:15%;width:10px;height:10px;background:var(--color-primary);border-radius:var(--rounded-full);animation:aboutPulse 3s ease-in-out infinite}
.about-hero-decoration--circle-2{bottom:40%;right:18%;width:8px;height:8px;background:var(--color-accent);border-radius:var(--rounded-full);animation:aboutPulse 4s ease-in-out infinite 1s}
@keyframes heartPulse{0%,100%{transform:scale(1);opacity:0.4}
50%{transform:scale(1.15);opacity:0.6}
}
@keyframes aboutPulse{0%,100%{opacity:0.4;transform:scale(1)}
50%{opacity:0.7;transform:scale(1.3)}
}
.pricing-hero{background:linear-gradient(135deg,#fdfaf3 0%,var(--bg-primary) 50%,#f9f6ef 100%)}
.pricing-hero::before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(212,175,55,0.12) 0%,transparent 70%);border-radius:var(--rounded-full);animation:pricingFloat 12s ease-in-out infinite}
.pricing-hero::after{content:'';position:absolute;bottom:-80px;left:-80px;width:300px;height:300px;background:radial-gradient(circle,rgba(212,175,55,0.08) 0%,transparent 70%);border-radius:var(--rounded-full);animation:pricingFloat 10s ease-in-out infinite reverse}
@keyframes pricingFloat{0%,100%{transform:translate(0,0) rotate(0deg)}
50%{transform:translate(10px,-10px) rotate(5deg)}
}
.pricing-hero-decoration--diamond-1{top:20%;left:10%;width:50px;height:50px;background:linear-gradient(135deg,var(--color-gold) 0%,#e8c547 100%);transform:rotate(45deg);animation:diamondRotate 15s linear infinite;opacity:0.25}
.pricing-hero-decoration--diamond-2{top:35%;right:8%;width:35px;height:35px;border:2px solid var(--color-gold);transform:rotate(45deg);animation:diamondRotate 20s linear infinite reverse;opacity:0.4}
.pricing-hero-decoration--diamond-3{bottom:25%;left:20%;width:25px;height:25px;background:var(--color-gold);transform:rotate(45deg);animation:diamondPulse 4s ease-in-out infinite;opacity:0.2}
@keyframes diamondRotate{from{transform:rotate(45deg)}
to{transform:rotate(405deg)}
}
@keyframes diamondPulse{0%,100%{opacity:0.2;transform:rotate(45deg) scale(1)}
50%{opacity:0.4;transform:rotate(45deg) scale(1.2)}
}
.pricing-hero-decoration--line-1{top:40%;right:15%;width:80px;height:2px;background:linear-gradient(90deg,transparent 0%,var(--color-gold) 50%,transparent 100%);opacity:0.3;animation:lineSlide 6s ease-in-out infinite}
.pricing-hero-decoration--line-2{bottom:35%;left:12%;width:60px;height:2px;background:linear-gradient(90deg,transparent 0%,var(--color-gold) 50%,transparent 100%);opacity:0.25;animation:lineSlide 8s ease-in-out infinite reverse}
@keyframes lineSlide{0%,100%{transform:translateX(0);opacity:0.25}
50%{transform:translateX(10px);opacity:0.5}
}
.pricing-hero-decoration--dot-1{top:25%;right:25%;width:6px;height:6px;background:var(--color-gold);border-radius:var(--rounded-full);animation:aboutPulse 3s ease-in-out infinite}
.pricing-hero-decoration--dot-2{bottom:30%;right:30%;width:8px;height:8px;background:var(--color-gold);border-radius:var(--rounded-full);animation:aboutPulse 4s ease-in-out infinite 0.5s}
:root{--color-purple-light:#e8e0f0;--color-purple:#a78bba;--color-purple-dark:#8b6aa3}
.gallery-hero{background:linear-gradient(135deg,#f5f0fa 0%,var(--bg-primary) 50%,#efe8f5 100%)}
.gallery-hero::before{content:'';position:absolute;top:-70px;right:-70px;width:320px;height:320px;background:radial-gradient(circle,rgba(167,139,186,0.15) 0%,transparent 70%);border-radius:var(--rounded-full);animation:galleryFloat 9s ease-in-out infinite}
.gallery-hero::after{content:'';position:absolute;bottom:-50px;left:-50px;width:250px;height:250px;background:radial-gradient(circle,rgba(167,139,186,0.1) 0%,transparent 70%);border-radius:var(--rounded-full);animation:galleryFloat 11s ease-in-out infinite reverse}
@keyframes galleryFloat{0%,100%{transform:translate(0,0) scale(1)}
50%{transform:translate(12px,-12px) scale(1.03)}
}
.gallery-hero-decoration--frame-1{top:18%;left:8%;width:60px;height:45px;border:3px solid var(--color-purple);border-radius:var(--rounded);animation:frameFloat 8s ease-in-out infinite;opacity:0.3}
.gallery-hero-decoration--frame-1::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;background:var(--color-purple-light);border-radius:var(--rounded-full)}
.gallery-hero-decoration--frame-2{top:30%;right:10%;width:45px;height:55px;border:2px solid var(--color-purple);border-radius:var(--rounded);animation:frameFloat 10s ease-in-out infinite 1s;opacity:0.25}
.gallery-hero-decoration--frame-2::after{content:'';position:absolute;bottom:-8px;left:50%;transform:translateX(-50%);width:20px;height:6px;background:var(--color-purple);border-radius:var(--rounded);opacity:0.5}
@keyframes frameFloat{0%,100%{transform:rotate(-5deg) translateY(0)}
50%{transform:rotate(5deg) translateY(-10px)}
}
.gallery-hero-decoration--polaroid{bottom:25%;left:15%;width:40px;height:48px;background:var(--color-white);border-radius:var(--rounded-sm);box-shadow:0 2px 8px rgba(0,0,0,0.1);animation:polaroidFloat 7s ease-in-out infinite;opacity:0.5}
.gallery-hero-decoration--polaroid::before{content:'';position:absolute;top:4px;left:4px;right:4px;height:28px;background:linear-gradient(135deg,var(--color-purple-light) 0%,var(--color-purple) 100%);border-radius:var(--rounded-sm)}
@keyframes polaroidFloat{0%,100%{transform:rotate(-8deg)}
50%{transform:rotate(3deg) translateY(-5px)}
}
.gallery-hero-decoration--aperture{bottom:35%;right:20%;width:50px;height:50px;border:3px solid var(--color-purple);border-radius:var(--rounded-full);animation:apertureRotate 20s linear infinite;opacity:0.2}
.gallery-hero-decoration--aperture::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;border:2px solid var(--color-purple);border-radius:var(--rounded-full)}
@keyframes apertureRotate{from{transform:rotate(0deg)}
to{transform:rotate(360deg)}
}
.gallery-hero-decoration--dot-1{top:45%;left:25%;width:8px;height:8px;background:var(--color-purple);border-radius:var(--rounded-full);animation:aboutPulse 3.5s ease-in-out infinite}
.gallery-hero-decoration--dot-2{top:20%;right:30%;width:6px;height:6px;background:var(--color-purple-light);border-radius:var(--rounded-full);animation:aboutPulse 4.5s ease-in-out infinite 1s}
:root{--color-blue-light:#e3f0fb;--color-blue:#5b9bd5;--color-blue-dark:#4a8ac4}
.contact-hero{background:linear-gradient(135deg,#eef6fc 0%,var(--bg-primary) 50%,#e8f2fa 100%)}
.contact-hero::before{content:'';position:absolute;top:-90px;right:-90px;width:380px;height:380px;background:radial-gradient(circle,rgba(91,155,213,0.12) 0%,transparent 70%);border-radius:var(--rounded-full);animation:contactFloat 11s ease-in-out infinite}
.contact-hero::after{content:'';position:absolute;bottom:-70px;left:-70px;width:280px;height:280px;background:radial-gradient(circle,rgba(91,155,213,0.08) 0%,transparent 70%);border-radius:var(--rounded-full);animation:contactFloat 13s ease-in-out infinite reverse}
@keyframes contactFloat{0%,100%{transform:translate(0,0) scale(1)}
50%{transform:translate(18px,-18px) scale(1.02)}
}
.contact-hero-decoration--envelope{top:20%;left:10%;width:50px;height:35px;background:var(--color-blue-light);border-radius:var(--rounded);animation:envelopeFloat 8s ease-in-out infinite;opacity:0.5}
.contact-hero-decoration--envelope::before{content:'';position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(135deg,transparent 40%,var(--color-blue) 40%,var(--color-blue) 60%,transparent 60%);opacity:0.4}
.contact-hero-decoration--envelope::after{content:'';position:absolute;top:-8px;left:50%;transform:translateX(-50%) rotate(45deg);width:25px;height:25px;background:var(--color-blue-light);border-top:2px solid var(--color-blue);border-right:2px solid var(--color-blue);opacity:0.6}
@keyframes envelopeFloat{0%,100%{transform:rotate(-5deg) translateY(0)}
50%{transform:rotate(5deg) translateY(-12px)}
}
.contact-hero-decoration--bubble-1{top:30%;right:12%;width:55px;height:40px;background:var(--color-blue);border-radius:var(--rounded-2xl);animation:bubbleFloat 9s ease-in-out infinite;opacity:0.2}
.contact-hero-decoration--bubble-1::after{content:'';position:absolute;bottom:-8px;left:15px;width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;border-top:12px solid var(--color-blue)}
.contact-hero-decoration--bubble-2{bottom:30%;left:18%;width:40px;height:30px;background:var(--color-blue-light);border-radius:var(--rounded-xl);animation:bubbleFloat 7s ease-in-out infinite 1s;opacity:0.4}
.contact-hero-decoration--bubble-2::after{content:'';position:absolute;bottom:-6px;right:10px;width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-top:10px solid var(--color-blue-light)}
@keyframes bubbleFloat{0%,100%{transform:translateY(0) scale(1)}
50%{transform:translateY(-8px) scale(1.05)}
}
.contact-hero-decoration--dots{bottom:40%;right:25%;display:flex;gap:4px;opacity:0.4}
.contact-hero-decoration--dots span{width:8px;height:8px;background:var(--color-blue);border-radius:var(--rounded-full);animation:dotBounce 1.5s ease-in-out infinite}
.contact-hero-decoration--dots span:nth-child(2){animation-delay:0.2s}
.contact-hero-decoration--dots span:nth-child(3){animation-delay:0.4s}
@keyframes dotBounce{0%,60%,100%{transform:translateY(0)}
30%{transform:translateY(-8px)}
}
.contact-hero-decoration--line{top:45%;left:30%;width:40px;height:2px;background:linear-gradient(90deg,var(--color-blue) 0%,transparent 100%);opacity:0.2;animation:lineSlide 5s ease-in-out infinite}
.contact-hero-decoration--circle-1{top:15%;right:30%;width:12px;height:12px;border:2px solid var(--color-blue);border-radius:var(--rounded-full);animation:aboutPulse 4s ease-in-out infinite}
.contact-hero-decoration--circle-2{bottom:25%;right:15%;width:8px;height:8px;background:var(--color-blue-light);border-radius:var(--rounded-full);animation:aboutPulse 3s ease-in-out infinite 0.5s}
[data-theme="dark"] .about-hero{background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-primary) 50%,var(--bg-tertiary) 100%)}
[data-theme="dark"] .about-hero::before,[data-theme="dark"] .about-hero::after{background:radial-gradient(circle,rgba(var(--color-primary-rgb),0.15) 0%,transparent 70%)}
[data-theme="dark"] .about-hero-decoration--heart-1::before,[data-theme="dark"] .about-hero-decoration--heart-1::after{background:var(--bg-tertiary)}
[data-theme="dark"] .about-hero-decoration--wave{background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 120' preserveAspectRatio='none'%3E%3Cpath d='M321.39,56.44c58-10.79,114.16-30.13,172-41.86,82.39-16.72,168.19-17.73,250.45-.39C823.78,31,906.67,72,985.66,92.83c70.05,18.48,146.53,26.09,214.34,3V0H0V27.35A600.21,600.21,0,0,0,321.39,56.44Z' fill='%230f3460' opacity='0.4'/%3E%3C/svg%3E") no-repeat bottom center;background-size:cover}
[data-theme="dark"] .pricing-hero{background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-primary) 50%,var(--bg-tertiary) 100%)}
[data-theme="dark"] .pricing-hero::before,[data-theme="dark"] .pricing-hero::after{background:radial-gradient(circle,rgba(212,175,55,0.1) 0%,transparent 70%)}
[data-theme="dark"] .pricing-hero-decoration--diamond-1{background:linear-gradient(135deg,var(--color-gold) 0%,#c9a227 100%);opacity:0.15}
[data-theme="dark"] .gallery-hero{background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-primary) 50%,var(--bg-tertiary) 100%)}
[data-theme="dark"] .gallery-hero::before,[data-theme="dark"] .gallery-hero::after{background:radial-gradient(circle,rgba(167,139,186,0.1) 0%,transparent 70%)}
[data-theme="dark"] .gallery-hero-decoration--polaroid{background:var(--bg-tertiary)}
[data-theme="dark"] .contact-hero{background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-primary) 50%,var(--bg-tertiary) 100%)}
[data-theme="dark"] .contact-hero::before,[data-theme="dark"] .contact-hero::after{background:radial-gradient(circle,rgba(91,155,213,0.1) 0%,transparent 70%)}
[data-theme="dark"] .contact-hero-decoration--envelope{background:var(--bg-tertiary)}
[data-theme="dark"] .contact-hero-decoration--bubble-2{background:var(--bg-tertiary)}
@media (max-width:767px){.page-hero{padding:var(--space-12) 0}
.page-hero-title{font-size:var(--text-4xl)}
.page-hero-subtitle{font-size:var(--text-base);padding:0 var(--space-4)}
.page-hero-decoration,.about-hero-decoration--heart-1,.about-hero-decoration--heart-2,.about-hero-decoration--circle-1,.about-hero-decoration--circle-2,.pricing-hero-decoration--diamond-1,.pricing-hero-decoration--diamond-2,.pricing-hero-decoration--diamond-3,.pricing-hero-decoration--line-1,.pricing-hero-decoration--line-2,.pricing-hero-decoration--dot-1,.pricing-hero-decoration--dot-2,.gallery-hero-decoration--frame-1,.gallery-hero-decoration--frame-2,.gallery-hero-decoration--polaroid,.gallery-hero-decoration--aperture,.gallery-hero-decoration--dot-1,.gallery-hero-decoration--dot-2,.contact-hero-decoration--envelope,.contact-hero-decoration--bubble-1,.contact-hero-decoration--bubble-2,.contact-hero-decoration--dots,.contact-hero-decoration--line,.contact-hero-decoration--circle-1,.contact-hero-decoration--circle-2{display:none}
.about-hero-decoration--wave{display:block;height:40px}
}
@media (min-width:768px) and (max-width:1023px){.page-hero-title{font-size:var(--text-5xl)}
.page-hero-decoration{opacity:0.3}
}
.notification-container{position:fixed;top:1rem;right:1rem;z-index:var(--z-notification,1080);display:flex;flex-direction:column;gap:0.75rem;max-width:420px;width:calc(100vw - 2rem);pointer-events:none}
@media (max-width:480px){.notification-container{top:0.5rem;right:0.5rem;left:0.5rem;width:auto;max-width:none}
}
.notification{pointer-events:auto;display:flex;flex-direction:column;background:var(--bg-primary,#ffffff);border-radius:0.75rem;box-shadow:0 10px 40px rgba(0,0,0,0.15),0 0 0 1px rgba(0,0,0,0.05);overflow:hidden;animation:notification-slide-in 0.3s ease-out;transform-origin:top right}
.notification.removing{animation:notification-slide-out 0.3s ease-in forwards}
@keyframes notification-slide-in{from{opacity:0;transform:translateX(100%)}
to{opacity:1;transform:translateX(0)}
}
@keyframes notification-slide-out{from{opacity:1;transform:translateX(0);max-height:200px;margin-bottom:0.75rem}
to{opacity:0;transform:translateX(100%);max-height:0;margin-bottom:0}
}
.notification-header{display:flex;align-items:flex-start;gap:0.75rem;padding:1rem}
.notification-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%}
.notification-icon svg{width:14px;height:14px}
.notification.success .notification-icon{background:rgba(16,185,129,0.15);color:#059669}
.notification.error .notification-icon{background:rgba(239,68,68,0.15);color:#dc2626}
.notification.warning .notification-icon{background:rgba(251,191,36,0.15);color:#d97706}
.notification.info .notification-icon{background:rgba(59,130,246,0.15);color:#2563eb}
.notification-content{flex:1;min-width:0}
.notification-title{font-size:0.875rem;font-weight:600;color:var(--text-primary,#1f2937);margin:0;line-height:1.4}
.notification-message{font-size:0.8125rem;color:var(--text-secondary,#6b7280);margin:0.25rem 0 0;line-height:1.5}
.notification-close{flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:0.375rem;cursor:pointer;color:var(--text-muted,#9ca3af);transition:all 0.15s;margin:-0.25rem -0.25rem 0 0}
.notification-close:hover{background:var(--bg-tertiary,#f3f4f6);color:var(--text-primary,#1f2937)}
.notification-close svg{width:16px;height:16px}
.notification{border-left:4px solid transparent}
.notification.success{border-left-color:#10b981}
.notification.error{border-left-color:#ef4444}
.notification.warning{border-left-color:#f59e0b}
.notification.info{border-left-color:#3b82f6}
.notification-details{display:none;padding:0 1rem 1rem 3.25rem}
.notification.expanded .notification-details{display:block}
.notification-details-content{background:var(--bg-tertiary,#f3f4f6);border-radius:0.5rem;padding:0.75rem;font-size:0.75rem;color:var(--text-secondary,#6b7280);font-family:ui-monospace,SFMono-Regular,"SF Mono",Consolas,"Liberation Mono",Menlo,monospace;white-space:pre-wrap;word-break:break-word;max-height:200px;overflow-y:auto}
.notification-toggle-details{display:inline-flex;align-items:center;gap:0.25rem;padding:0.25rem 0.5rem;margin-top:0.5rem;font-size:0.75rem;font-weight:500;color:var(--color-primary,#b8860b);background:transparent;border:none;border-radius:0.25rem;cursor:pointer;transition:all 0.15s}
.notification-toggle-details:hover{background:rgba(var(--color-primary-rgb,184,134,11),0.1)}
.notification-toggle-details svg{width:12px;height:12px;transition:transform 0.2s}
.notification.expanded .notification-toggle-details svg{transform:rotate(180deg)}
.notification-progress{height:3px;background:var(--color-gray-200,#e5e7eb);overflow:hidden}
.notification-progress-bar{height:100%;width:100%;transform-origin:left;animation:notification-progress-shrink linear forwards}
.notification.success .notification-progress-bar{background:#10b981}
.notification.error .notification-progress-bar{background:#ef4444}
.notification.warning .notification-progress-bar{background:#f59e0b}
.notification.info .notification-progress-bar{background:#3b82f6}
@keyframes notification-progress-shrink{from{transform:scaleX(1)}
to{transform:scaleX(0)}
}
.notification:hover .notification-progress-bar{animation-play-state:paused}
.notification-actions{display:flex;gap:0.5rem;padding:0 1rem 1rem 3.25rem}
.notification-action{padding:0.5rem 1rem;font-size:0.8125rem;font-weight:500;border-radius:0.375rem;cursor:pointer;transition:all 0.15s}
.notification-action-primary{background:var(--color-primary,#b8860b);color:white;border:none}
.notification-action-primary:hover{filter:brightness(1.1)}
.notification-action-secondary{background:transparent;color:var(--text-secondary,#6b7280);border:1px solid var(--color-gray-300,#d1d5db)}
.notification-action-secondary:hover{background:var(--bg-tertiary,#f3f4f6);color:var(--text-primary,#1f2937)}
[data-theme="dark"] .notification{background:var(--bg-secondary,#1f2937);box-shadow:0 10px 40px rgba(0,0,0,0.4),0 0 0 1px rgba(255,255,255,0.05)}
[data-theme="dark"] .notification-title{color:var(--text-primary,#f9fafb)}
[data-theme="dark"] .notification-message{color:var(--text-secondary,#9ca3af)}
[data-theme="dark"] .notification-close:hover{background:var(--bg-tertiary,#374151)}
[data-theme="dark"] .notification-details-content{background:var(--bg-tertiary,#374151);color:var(--text-secondary,#9ca3af)}
[data-theme="dark"] .notification-progress{background:var(--color-gray-300,#374151)}
[data-theme="dark"] .notification.success .notification-icon{background:rgba(16,185,129,0.25);color:#34d399}
[data-theme="dark"] .notification.error .notification-icon{background:rgba(239,68,68,0.25);color:#f87171}
[data-theme="dark"] .notification.warning .notification-icon{background:rgba(251,191,36,0.25);color:#fbbf24}
[data-theme="dark"] .notification.info .notification-icon{background:rgba(59,130,246,0.25);color:#60a5fa}
[data-theme="dark"] .notification-action-secondary{border-color:var(--color-gray-300,#4b5563)}
[data-theme="dark"] .notification-action-secondary:hover{background:var(--bg-tertiary,#374151)}
.badge{display:inline-flex;align-items:center;gap:0.25rem;padding:0.125rem 0.5rem;border-radius:var(--rounded-full);font-size:0.625rem;font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:0.05em;line-height:1.4;white-space:nowrap}
.badge svg{width:0.75rem;height:0.75rem;flex-shrink:0}
.badge-xs{padding:0.0625rem 0.375rem;font-size:0.5625rem}
.badge-sm{padding:0.125rem 0.5rem;font-size:0.625rem}
.badge-md{padding:0.25rem 0.625rem;font-size:0.6875rem}
.badge-success{background:var(--color-success);color:white}
.badge-warning{background:var(--color-warning);color:white}
.badge-error,.badge-danger{background:var(--color-error);color:white}
.badge-info{background:#3b82f6;color:white}
.badge-primary{background:var(--color-primary);color:white}
.badge-secondary,.badge-muted{background:var(--color-gray-500);color:white}
.badge-purple{background:#8b5cf6;color:white}
.badge-pink{background:#ec4899;color:white}
.badge-cyan{background:#06b6d4;color:white}
.badge-orange{background:#f97316;color:white}
.badge-success-soft{background:var(--color-success-light,rgba(16,185,129,0.15));color:var(--color-success-dark,#065f46)}
.badge-warning-soft{background:rgba(245,158,11,0.15);color:#92400e}
.badge-error-soft,.badge-danger-soft{background:rgba(239,68,68,0.15);color:#991b1b}
.badge-info-soft{background:rgba(59,130,246,0.15);color:#1e40af}
.badge-primary-soft{background:rgba(var(--color-primary-rgb),0.15);color:var(--color-primary)}
.badge-secondary-soft{background:var(--color-gray-100);color:var(--color-gray-600)}
.badge-paid{background:var(--color-success);color:white}
.badge-pending{background:var(--color-warning);color:white}
.badge-cancelled{background:var(--color-error);color:white}
.badge-shipped{background:#3b82f6;color:white}
.badge-delivered{background:#10b981;color:white}
.badge-returned{background:#6b7280;color:white}
.badge-refunded{background:#8b5cf6;color:white}
.badge-unread{background:var(--color-primary);color:white}
.badge-read{background:var(--color-gray-500);color:white}
.badge-replied{background:var(--color-success);color:white}
.badge-active{background:var(--color-success-light,rgba(16,185,129,0.15));color:var(--color-success-dark,#065f46)}
.badge-inactive{background:var(--color-gray-100);color:var(--color-gray-600)}
.badge-published{background:var(--color-success);color:white}
.badge-draft{background:var(--color-warning);color:white}
.badge-action-create{background:#10b981;color:white}
.badge-action-update{background:#3b82f6;color:white}
.badge-action-delete{background:#ef4444;color:white}
.badge-action-hard-delete{background:#991b1b;color:white}
.badge-action-login{background:#8b5cf6;color:white}
.badge-action-logout{background:#6b7280;color:white}
.badge-action-login-failed{background:#f59e0b;color:white}
.badge-action-export{background:#06b6d4;color:white}
.badge-action-status-change{background:#ec4899;color:white}
.badge-action-bulk{background:#f97316;color:white}
.badge-media{background:rgba(0,0,0,0.7);backdrop-filter:blur(4px)}
.badge-media-image{background:rgba(59,130,246,0.9);color:white}
.badge-media-video{background:rgba(139,92,246,0.9);color:white}
.badge-media-audio{background:rgba(236,72,153,0.9);color:white}
.badge-category-general{background:#6b7280;color:white}
.badge-category-rental{background:#3b82f6;color:white}
.badge-category-event{background:#10b981;color:white}
.badge-category-payment{background:#f59e0b;color:white}
.badge-category-shipping{background:#8b5cf6;color:white}
.badge-category-technical{background:#ef4444;color:white}
.badge-dot{display:inline-flex;align-items:center;gap:0.375rem;background:transparent;padding:0;color:var(--text-primary);font-size:var(--text-sm);font-weight:var(--font-medium);text-transform:none;letter-spacing:normal}
.badge-dot::before{content:'';width:0.5rem;height:0.5rem;border-radius:50%;background:currentColor;flex-shrink:0}
.badge-dot.badge-success::before{background:var(--color-success)}
.badge-dot.badge-warning::before{background:var(--color-warning)}
.badge-dot.badge-error::before{background:var(--color-error)}
.badge-dot.badge-info::before{background:#3b82f6}
.badge-dot.badge-primary::before{background:var(--color-primary)}
.badge-dot.badge-secondary::before{background:var(--color-gray-500)}
.badge-outline{background:transparent;border:1px solid currentColor}
.badge-outline.badge-success{color:var(--color-success)}
.badge-outline.badge-warning{color:var(--color-warning)}
.badge-outline.badge-error{color:var(--color-error)}
.badge-outline.badge-info{color:#3b82f6}
.badge-outline.badge-primary{color:var(--color-primary)}
.badge-outline.badge-secondary{color:var(--color-gray-500)}
[data-theme="dark"] .badge-secondary,[data-theme="dark"] .badge-muted{background:var(--color-gray-600)}
[data-theme="dark"] .badge-success-soft{background:rgba(16,185,129,0.25);color:#6ee7b7}
[data-theme="dark"] .badge-warning-soft{background:rgba(245,158,11,0.25);color:#fcd34d}
[data-theme="dark"] .badge-error-soft,[data-theme="dark"] .badge-danger-soft{background:rgba(239,68,68,0.25);color:#fca5a5}
[data-theme="dark"] .badge-info-soft{background:rgba(59,130,246,0.25);color:#93c5fd}
[data-theme="dark"] .badge-primary-soft{background:rgba(var(--color-primary-rgb),0.25)}
[data-theme="dark"] .badge-secondary-soft,[data-theme="dark"] .badge-active{background:var(--bg-tertiary);color:var(--text-secondary)}
[data-theme="dark"] .badge-inactive{background:var(--bg-tertiary);color:var(--text-muted)}
[data-theme="dark"] .badge-read{background:var(--color-gray-600)}
.admin-status-badge{@extend .badge}
.admin-status-badge.status-paid{@extend .badge-success}
.admin-status-badge.status-pending{@extend .badge-warning}
.admin-status-badge.status-default{@extend .badge-secondary}
.status-badge--active{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-2);font-size:var(--text-xs);font-weight:var(--font-semibold);border-radius:var(--rounded-full);background:#16a34a;color:white;box-shadow:0 2px 8px rgba(0,0,0,0.25)}
.status-badge--inactive{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-2);font-size:var(--text-xs);font-weight:var(--font-semibold);border-radius:var(--rounded-full);background:rgba(0,0,0,0.7);color:white;box-shadow:0 2px 8px rgba(0,0,0,0.25)}
.section{padding:var(--space-16) 0}
.section-sm{padding:var(--space-12) 0}
.section-lg{padding:var(--space-24) 0}
.section-title{text-align:center;margin-bottom:var(--space-4)}
.section-subtitle{text-align:center;font-size:var(--text-lg);color:var(--text-secondary);max-width:600px;margin:0 auto var(--space-12)}
.grid{display:grid;gap:var(--space-6)}
.grid-2{grid-template-columns:repeat(1,1fr)}
.grid-3{grid-template-columns:repeat(1,1fr)}
.grid-4{grid-template-columns:repeat(1,1fr)}
.grid-5{grid-template-columns:repeat(1,1fr)}
@media (min-width:640px){.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(2,1fr)}
.grid-4{grid-template-columns:repeat(2,1fr)}
.grid-5{grid-template-columns:repeat(2,1fr)}
}
@media (min-width:1024px){.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-5{grid-template-columns:repeat(5,1fr)}
}
.flex{display:flex}
.flex-col{flex-direction:column}
.items-center{align-items:center}
.justify-center{justify-content:center}
.justify-between{justify-content:space-between}
.gap-2{gap:var(--space-2)}
.gap-4{gap:var(--space-4)}
.gap-6{gap:var(--space-6)}
.gap-8{gap:var(--space-8)}
.hero{position:relative;min-height:calc(100vh - var(--header-height));display:flex;align-items:center;justify-content:flex-end;overflow:hidden;background:var(--bg-primary);padding:0 var(--space-8)}
.hero::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(to left,rgba(255,255,255,0.75) 0%,rgba(255,255,255,0.6) 30%,rgba(255,255,255,0.4) 50%,transparent 70%);z-index:1}
[data-theme="dark"] .hero::before{background:linear-gradient(to left,rgba(30,30,30,0.95) 0%,rgba(30,30,30,0.85) 30%,rgba(30,30,30,0.5) 50%,transparent 70%)}
.hero-content{position:relative;z-index:2;max-width:550px;text-align:right;padding-right:var(--space-12);margin-right:5%}
.hero-content .btn-group{justify-content:flex-end}
.hero-title{font-family:var(--font-heading);font-size:var(--text-6xl);line-height:1.1;margin-bottom:var(--space-6)}
@media (min-width:768px){.hero-title{font-size:var(--text-7xl)}
}
.hero-subtitle{font-size:var(--text-xl);color:var(--text-primary);opacity:0.85;margin-bottom:var(--space-8);line-height:var(--leading-relaxed)}
.hero-image{position:absolute;top:0;left:0;right:0;bottom:0;width:100%;height:100%;z-index:0;overflow:hidden}
.hero-image img{width:100%;height:100%;object-fit:cover;object-position:center;animation:heroZoomOut 20s ease-out forwards;transform-origin:center center}
@keyframes heroZoomOut{0%{transform:scale(1.15)}
100%{transform:scale(1)}
}
@media (min-width:768px) and (max-width:1023px){.hero-image img{object-position:right center}
}
@media (max-width:767px){.hero-image{display:none}
.hero{justify-content:center;padding:0 var(--space-4)}
.hero-content{text-align:center;padding-right:0;margin-right:0}
.hero-content .btn-group{justify-content:center}
}
.hero-decoration{position:absolute;border-radius:var(--rounded-full);opacity:0.5}
.hero-decoration-1{width:300px;height:300px;background-color:var(--color-accent);top:10%;right:20%;animation:float 6s ease-in-out infinite}
.hero-decoration-2{width:200px;height:200px;background-color:var(--color-primary);opacity:0.2;bottom:20%;left:10%;animation:float 8s ease-in-out infinite reverse}
@keyframes float{0%,100%{transform:translateY(0) rotate(0deg)}
50%{transform:translateY(-20px) rotate(5deg)}
}
.features{background-color:var(--bg-secondary)}
.feature-item{text-align:center;padding:var(--space-6)}
.feature-icon{width:80px;height:80px;margin:0 auto var(--space-4);display:flex;align-items:center;justify-content:center;background-color:var(--color-accent);border-radius:var(--rounded-2xl);color:var(--color-primary)}
.feature-icon svg{width:40px;height:40px}
.feature-title{font-size:var(--text-xl);margin-bottom:var(--space-2)}
.feature-description{font-size:var(--text-sm);color:var(--text-secondary)}
.vision-section{background-color:var(--bg-primary)}
.vision-quote{text-align:center;margin-bottom:var(--space-8)}
.vision-quote p{font-size:var(--text-xl);font-style:italic;color:var(--color-primary);margin-bottom:var(--space-2)}
.vision-quote cite{font-size:var(--text-base);color:var(--text-secondary);font-style:normal}
.vision-image{margin-bottom:var(--space-10);border-radius:var(--rounded-xl);overflow:hidden;box-shadow:var(--shadow-xl)}
.vision-image img{width:100%;height:auto;display:block;object-fit:cover;max-height:500px}
.vision-columns{gap:var(--space-8)}
.vision-column{text-align:left}
.vision-title{font-size:var(--text-xl);font-weight:var(--font-bold);margin-bottom:var(--space-3);color:var(--text-primary);border-bottom:3px solid var(--color-primary);padding-bottom:var(--space-2);display:inline-block}
.vision-text{font-size:var(--text-base);color:var(--text-secondary);line-height:1.7}
.accordion{border:1px solid var(--color-gray-200);border-radius:var(--rounded-xl);overflow:hidden}
.accordion-item{border-bottom:1px solid var(--color-gray-200)}
.accordion-item:last-child{border-bottom:none}
.accordion-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-4) var(--space-6);background:none;border:none;font-family:var(--font-body);font-size:var(--text-base);font-weight:var(--font-medium);text-align:left;color:var(--text-primary);cursor:pointer;transition:background-color var(--transition-fast)}
.accordion-header:hover{background-color:var(--color-gray-50)}
.accordion-icon{width:1.25rem;height:1.25rem;color:var(--text-muted);transition:transform var(--transition-base)}
.accordion-item.is-open .accordion-icon{transform:rotate(180deg)}
.accordion-content{max-height:0;overflow:hidden;transition:max-height var(--transition-base)}
.accordion-item.is-open .accordion-content{max-height:500px}
.accordion-body{padding:0 var(--space-6) var(--space-4);font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed)}
[data-theme="dark"] .accordion{border-color:var(--bg-tertiary)}
[data-theme="dark"] .accordion-item{border-color:var(--bg-tertiary)}
[data-theme="dark"] .accordion-header:hover{background-color:var(--bg-tertiary)}
.lightbox{position:fixed;inset:0;background-color:rgba(0,0,0,0.9);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);opacity:0;visibility:hidden;transition:all var(--transition-base)}
.lightbox.is-open{opacity:1;visibility:visible}
.lightbox-content{position:relative;max-width:90vw;max-height:90vh}
.lightbox-content img{max-width:100%;max-height:90vh;object-fit:contain}
.lightbox-close{position:absolute;top:var(--space-4);right:var(--space-4);width:48px;height:48px;background-color:rgba(255,255,255,0.1);border:none;border-radius:var(--rounded-full);color:var(--color-white);cursor:pointer;transition:background-color var(--transition-fast)}
.lightbox-close:hover{background-color:rgba(255,255,255,0.2)}
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;background-color:rgba(255,255,255,0.1);border:none;border-radius:var(--rounded-full);color:var(--color-white);cursor:pointer;transition:background-color var(--transition-fast)}
.lightbox-nav:hover{background-color:rgba(255,255,255,0.2)}
.lightbox-prev{left:var(--space-4)}
.lightbox-next{right:var(--space-4)}
.alert{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);border-radius:var(--rounded-lg);margin-bottom:var(--space-4)}
.alert-icon{flex-shrink:0;width:1.25rem;height:1.25rem}
.alert-content{flex:1}
.alert-title{font-weight:var(--font-semibold);margin-bottom:var(--space-1)}
.alert-message{font-size:var(--text-sm)}
.alert-success{background-color:#e8f5e9;color:#2e7d32}
.alert-error{background-color:#ffebee;color:#c62828}
.alert-warning{background-color:#fff3e0;color:#ef6c00}
.alert-info{background-color:#e3f2fd;color:#1565c0}
[data-theme="dark"] .alert-success{background-color:rgba(76,175,80,0.2)}
[data-theme="dark"] .alert-error{background-color:rgba(244,67,54,0.2)}
[data-theme="dark"] .alert-warning{background-color:rgba(255,152,0,0.2)}
[data-theme="dark"] .alert-info{background-color:rgba(33,150,243,0.2)}
.main-content{padding-top:var(--header-height)}
.page-header{padding:var(--space-16) 0;background:linear-gradient(135deg,var(--color-accent-light) 0%,var(--bg-primary) 100%);text-align:center;overflow:hidden}
.page-header-title{font-family:var(--font-heading);font-size:var(--text-5xl);margin-bottom:var(--space-4);animation:pageHeaderFadeIn 0.8s ease-out forwards;opacity:0}
.page-header-subtitle{font-size:var(--text-lg);color:var(--text-secondary);max-width:600px;margin:0 auto;animation:pageHeaderFadeIn 0.8s ease-out 0.2s forwards;opacity:0}
@keyframes pageHeaderFadeIn{0%{opacity:0;transform:translateY(20px)}
100%{opacity:1;transform:translateY(0)}
}
.timeline{position:relative;max-width:900px;margin:0 auto;padding:var(--space-8) 0}
.timeline::before{content:'';position:absolute;left:50%;transform:translateX(-50%);width:3px;height:100%;background:var(--color-gray-300);top:0}
.timeline::after{content:'';position:absolute;left:50%;transform:translateX(-50%);width:3px;height:0;background:var(--color-primary);top:0;transition:height 0.3s ease-out}
.timeline.is-animating::after{height:var(--timeline-progress,0%)}
.timeline-item{position:relative;margin-bottom:var(--space-12);opacity:0;transform:translateY(30px);transition:all 0.6s ease-out}
.timeline-item.is-visible{opacity:1;transform:translateY(0)}
.timeline-item:last-child{margin-bottom:0}
.timeline-milestone{position:relative;display:flex;align-items:center;margin-bottom:var(--space-8);padding-left:calc(50% + 15px)}
.timeline-item:nth-child(4n+1) .timeline-milestone{padding-left:0;padding-right:calc(50% + 15px);justify-content:flex-end}
.timeline-milestone-label{display:inline-block;background:var(--bg-primary);border:2px solid var(--color-gray-300);border-radius:var(--rounded-full);padding:var(--space-2) var(--space-6);font-weight:var(--font-semibold);color:var(--text-secondary);position:relative;transition:all 0.4s ease-out}
.timeline-item.is-visible .timeline-milestone-label{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-accent-light)}
.timeline-content{display:flex;align-items:flex-start;gap:var(--space-8)}
.timeline-content.left{flex-direction:row}
.timeline-content.right{flex-direction:row-reverse}
.timeline-box{flex:1;background:var(--bg-primary);border:1px solid var(--color-gray-200);border-radius:var(--rounded-xl);padding:var(--space-6);box-shadow:var(--shadow-md);max-width:380px}
.timeline-content.left .timeline-box{margin-left:auto;text-align:right}
.timeline-content.right .timeline-box{margin-right:auto;text-align:left}
.timeline-box-title{font-size:var(--text-xl);font-weight:var(--font-bold);margin-bottom:var(--space-2);color:var(--text-primary)}
.timeline-box-text{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.6}
.timeline-center{flex-shrink:0;width:50px;display:flex;flex-direction:column;align-items:center;position:relative;z-index:2}
.timeline-icon{width:44px;height:44px;background:var(--color-gray-300);border-radius:var(--rounded-full);display:flex;align-items:center;justify-content:center;color:white;transition:all 0.4s ease-out;transform:scale(0.8)}
.timeline-item.is-visible .timeline-icon{background:var(--color-primary);transform:scale(1)}
.timeline-icon svg{width:22px;height:22px}
.timeline-info{flex:1;max-width:380px}
.timeline-content.left .timeline-info{text-align:left}
.timeline-content.right .timeline-info{text-align:right}
.timeline-date{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-primary);margin-bottom:var(--space-1)}
.timeline-detail{font-size:var(--text-sm);color:var(--text-secondary)}
@keyframes timelineFadeIn{0%{opacity:0;transform:translateY(30px)}
100%{opacity:1;transform:translateY(0)}
}
@media (max-width:768px){.timeline::before,.timeline::after{left:20px}
.timeline-milestone,.timeline-item:nth-child(4n+1) .timeline-milestone{padding-left:50px;padding-right:0;justify-content:flex-start}
.timeline-milestone-label{position:relative}
.timeline-content,.timeline-content.left,.timeline-content.right{flex-direction:column;padding-left:60px}
.timeline-center{position:absolute;left:10px}
.timeline-icon{position:relative}
.timeline-box,.timeline-content.left .timeline-box,.timeline-content.right .timeline-box{max-width:100%;margin:0;text-align:left}
.timeline-info,.timeline-content.left .timeline-info,.timeline-content.right .timeline-info{text-align:left;max-width:100%}
}
.breadcrumb{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-4)}
.breadcrumb a{color:var(--text-muted)}
.breadcrumb a:hover{color:var(--color-primary)}
.breadcrumb-separator{color:var(--color-gray-400)}
.loading{display:flex;align-items:center;justify-content:center;padding:var(--space-8)}
.spinner{width:40px;height:40px;border:3px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:var(--rounded-full);animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}
}
.fade-in{animation:fadeIn var(--transition-base) ease-out}
@keyframes fadeIn{from{opacity:0;transform:translateY(20px)}
to{opacity:1;transform:translateY(0)}
}
.slide-up{animation:slideUp var(--transition-base) ease-out}
@keyframes slideUp{from{opacity:0;transform:translateY(40px)}
to{opacity:1;transform:translateY(0)}
}
