@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-font-weight:initial;--tw-tracking:initial;--tw-outline-style:solid}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--spacing:.25rem;--container-md:28rem;--container-lg:32rem;--container-xl:36rem;--text-base:1rem;--text-base--line-height:calc(1.5/1);--font-weight-extrabold:800;--tracking-tight:-.025em;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.mx-auto{margin-inline:auto}.contents{display:contents}.flex{display:flex}.hidden{display:none}.table{display:table}.max-w-md{max-width:var(--container-md)}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.flex-col{flex-direction:column}.gap-3{gap:calc(var(--spacing)*3)}.gap-6{gap:calc(var(--spacing)*6)}.rounded{border-radius:.25rem}.border{border-style:var(--tw-border-style);border-width:1px}.px-5{padding-inline:calc(var(--spacing)*5)}.py-10{padding-block:calc(var(--spacing)*10)}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.font-extrabold{--tw-font-weight:var(--font-weight-extrabold);font-weight:var(--font-weight-extrabold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}@media (min-width:40rem){.sm\:max-w-lg{max-width:var(--container-lg)}}@media (min-width:48rem){.md\:max-w-xl{max-width:var(--container-xl)}}}:root{--bg:#0a0a0b;--bg-card:#ffffff08;--bg-card-hover:#ffffff0f;--text:#f0f0f2;--text-muted:#8a8a96;--accent:#ff6b35;--accent-glow:#ff6b3540;--gradient-1:#ff6b35;--gradient-2:#ff2d78;--border:#ffffff0f;--radius:16px}html{scroll-behavior:smooth}body{font-family:var(--font-inter),var(--font-noto-sans-jp),-apple-system,sans-serif;background:var(--bg);color:var(--text);line-height:1.7;overflow-x:hidden}.container{max-width:1080px;margin:0 auto;padding:0 24px}.gradient-text{background:linear-gradient(135deg,var(--gradient-1),var(--gradient-2));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}nav{z-index:100;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);background:#0a0a0bcc;padding:16px 0;position:fixed;top:0;left:0;right:0}nav .container{justify-content:space-between;align-items:center;display:flex}.logo{letter-spacing:-.02em;font-size:1.3rem;font-weight:800}.nav-cta{background:linear-gradient(135deg,var(--gradient-1),var(--gradient-2));color:#fff;cursor:pointer;border:none;border-radius:999px;padding:8px 20px;font-size:.85rem;font-weight:600;text-decoration:none;transition:transform .2s,box-shadow .2s}.nav-cta:hover{box-shadow:0 4px 20px var(--accent-glow);transform:translateY(-1px)}.hero{text-align:center;padding:160px 0 100px;position:relative}.hero:before{content:"";background:radial-gradient(circle,var(--accent-glow)0%,transparent 70%);pointer-events:none;opacity:.4;width:600px;height:600px;position:absolute;top:0;left:50%;transform:translate(-50%)}.hero-badge{color:var(--accent);background:#ff6b351a;border:1px solid #ff6b3540;border-radius:999px;margin-bottom:24px;padding:6px 16px;font-size:.8rem;font-weight:600;display:inline-block}.hero h1{letter-spacing:-.03em;margin-bottom:20px;font-size:clamp(2.4rem,6vw,4rem);font-weight:800;line-height:1.2}.hero p{color:var(--text-muted);max-width:560px;margin:0 auto 40px;font-size:1.1rem}.hero-cta{background:linear-gradient(135deg,var(--gradient-1),var(--gradient-2));color:#fff;cursor:pointer;border:none;border-radius:999px;align-items:center;gap:8px;padding:14px 32px;font-size:1rem;font-weight:700;text-decoration:none;transition:transform .2s,box-shadow .2s;display:inline-flex}.hero-cta:hover{box-shadow:0 8px 32px var(--accent-glow);transform:translateY(-2px)}.hero-sub{color:var(--text-muted);margin-top:12px;font-size:.8rem}.demo{padding:60px 0 100px}.demo-card{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;max-width:840px;margin:0 auto;overflow:hidden}.demo-header{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:20px 28px;display:flex}.demo-dot{border-radius:50%;width:10px;height:10px}.demo-dot.r{background:#ff5f57}.demo-dot.y{background:#febc2e}.demo-dot.g{background:#28c840}.demo-body{grid-template-columns:1fr 1fr;min-height:420px;display:grid}@media (max-width:640px){.demo-body{grid-template-columns:1fr}}.demo-photo{background:#ffffff08;justify-content:center;align-items:center;min-height:300px;display:flex;position:relative;overflow:hidden}.demo-photo-placeholder{width:100%;height:100%;min-height:300px;color:var(--text-muted);background-color:#0000;background-image:linear-gradient(#ffffff08 1px,#0000 1px),linear-gradient(90deg,#ffffff08 1px,#0000 1px);background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:33.33% 33.33%;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;flex-direction:column;justify-content:center;align-items:center;gap:12px;font-size:.85rem;display:flex}.demo-photo-placeholder svg{opacity:.4}.demo-photo-overlay{color:var(--text-muted);background:#0009;border-radius:6px;padding:4px 10px;font-size:.7rem;position:absolute;top:12px;left:12px}.demo-result{border-left:1px solid var(--border);flex-direction:column;gap:16px;padding:28px;display:flex}@media (max-width:640px){.demo-result{border-left:none;border-top:1px solid var(--border)}}.score-display{align-items:center;gap:16px;display:flex}.score-ring{flex-shrink:0;width:72px;height:72px;position:relative}.score-ring svg{transform:rotate(-90deg)}.score-ring-bg{fill:none;stroke:#ffffff0f;stroke-width:5px}.score-ring-fill{fill:none;stroke:url(#score-gradient);stroke-width:5px;stroke-linecap:round;stroke-dasharray:188;stroke-dashoffset:38px;transition:stroke-dashoffset 1.5s}.score-number{font-size:1.4rem;font-weight:800;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.score-label{color:var(--text-muted);font-size:.85rem;line-height:1.5}.score-label strong{color:var(--text);margin-bottom:2px;font-size:1rem;display:block}.review-items{flex-direction:column;gap:10px;display:flex}.review-item{background:#ffffff05;border-radius:10px;align-items:center;gap:10px;padding:10px 14px;font-size:.85rem;display:flex}.review-item-icon{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.75rem;display:flex}.review-item-icon.good{color:#28c840;background:#28c84026}.review-item-icon.ok{color:#febc2e;background:#febc2e26}.review-item-icon.bad{color:#ff5f57;background:#ff5f5726}.review-item-text{color:var(--text-muted)}.review-item-text strong{color:var(--text);font-weight:600}.demo-ai-note{color:var(--text-muted);background:#ff6b350f;border:1px solid #ff6b3526;border-radius:10px;align-items:flex-start;gap:8px;margin-top:auto;padding:12px 16px;font-size:.78rem;line-height:1.6;display:flex}.demo-ai-note span{color:var(--accent);flex-shrink:0;font-weight:600}.pain{padding:80px 0}.pain h2{text-align:center;letter-spacing:-.02em;margin-bottom:48px;font-size:clamp(1.6rem,4vw,2.2rem);font-weight:800}.pain-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}@media (max-width:768px){.pain-grid{grid-template-columns:1fr}}.pain-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;transition:background .2s}.pain-card:hover{background:var(--bg-card-hover)}.pain-emoji{margin-bottom:16px;font-size:1.8rem}.pain-card h3{margin-bottom:8px;font-size:1rem;font-weight:700}.pain-card p{color:var(--text-muted);font-size:.85rem;line-height:1.7}.steps{padding:80px 0}.steps h2{text-align:center;letter-spacing:-.02em;margin-bottom:56px;font-size:clamp(1.6rem,4vw,2.2rem);font-weight:800}.steps-grid{grid-template-columns:repeat(3,1fr);gap:32px;display:grid}@media (max-width:768px){.steps-grid{grid-template-columns:1fr;gap:24px}}.step{text-align:center}.step-num{background:linear-gradient(135deg,var(--gradient-1),var(--gradient-2));border-radius:14px;justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:20px;font-size:1.1rem;font-weight:800;display:inline-flex}.step h3{margin-bottom:8px;font-size:1.05rem;font-weight:700}.step p{color:var(--text-muted);font-size:.85rem}.ideal{padding:80px 0}.ideal h2{text-align:center;letter-spacing:-.02em;margin-bottom:16px;font-size:clamp(1.6rem,4vw,2.2rem);font-weight:800}.ideal-sub{text-align:center;color:var(--text-muted);max-width:600px;margin-bottom:48px;margin-left:auto;margin-right:auto;font-size:.95rem}.ideal-demo{grid-template-columns:1fr 40px 1fr;align-items:center;gap:0;max-width:720px;margin:0 auto;display:grid}@media (max-width:640px){.ideal-demo{grid-template-columns:1fr;gap:16px}.ideal-arrow{transform:rotate(90deg)}}.ideal-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.ideal-card-img{height:200px;color:var(--text-muted);background:#ffffff08;justify-content:center;align-items:center;font-size:.8rem;display:flex}.ideal-card-body{padding:16px 20px}.ideal-card-label{text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px;font-size:.7rem;font-weight:700}.ideal-card-label.before{color:var(--text-muted)}.ideal-card-label.after{color:var(--accent)}.ideal-card-score{font-size:1.3rem;font-weight:800}.ideal-card-img--ai{background:linear-gradient(135deg,#ff6b3514,#ff2d7814)}.score-sub{color:var(--text-muted);font-size:.7rem}.score-sub--gradient{-webkit-text-fill-color:var(--text-muted)}.ideal-card-desc{color:var(--text-muted);margin-top:4px;font-size:.78rem}.ideal-arrow{color:var(--accent);justify-content:center;align-items:center;font-size:1.5rem;display:flex}.ideal-note{text-align:center;color:var(--text-muted);margin-top:24px;font-size:.8rem;font-style:italic}.features{padding:80px 0}.features h2{text-align:center;letter-spacing:-.02em;margin-bottom:48px;font-size:clamp(1.6rem,4vw,2.2rem);font-weight:800}.features-grid{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}@media (max-width:640px){.features-grid{grid-template-columns:1fr}}.feature-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;transition:background .2s,border-color .2s}.feature-card:hover{background:var(--bg-card-hover);border-color:#ff6b3533}.feature-icon{background:#ff6b351a;border-radius:12px;justify-content:center;align-items:center;width:42px;height:42px;margin-bottom:16px;font-size:1.2rem;display:flex}.feature-card h3{margin-bottom:6px;font-size:1rem;font-weight:700}.feature-card p{color:var(--text-muted);font-size:.85rem;line-height:1.7}.growth{padding:80px 0}.growth h2{text-align:center;letter-spacing:-.02em;margin-bottom:16px;font-size:clamp(1.6rem,4vw,2.2rem);font-weight:800}.growth-sub{text-align:center;color:var(--text-muted);margin-bottom:48px;font-size:.95rem}.growth-chart{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);max-width:600px;margin:0 auto;padding:32px}.growth-chart-header{justify-content:space-between;align-items:baseline;margin-bottom:24px;display:flex}.growth-chart-title{font-size:.9rem;font-weight:600}.growth-chart-period{color:var(--text-muted);font-size:.75rem}.growth-bars{align-items:flex-end;gap:12px;height:160px;display:flex}.growth-bar-group{flex-direction:column;flex:1;align-items:center;gap:8px;display:flex}.growth-bar{background:linear-gradient(180deg,var(--gradient-1),var(--gradient-2));border-radius:6px 6px 0 0;width:100%;min-height:8px;transition:height 1s}.growth-bar-label{color:var(--text-muted);font-size:.65rem}.growth-bar-score{font-size:.75rem;font-weight:700}.growth-bar-score--highlight{color:var(--accent)}.growth-stats{border-top:1px solid var(--border);grid-template-columns:repeat(3,1fr);gap:16px;margin-top:24px;padding-top:20px;display:grid}.growth-stat{text-align:center}.growth-stat-value{font-size:1.2rem;font-weight:800}.growth-stat-value.up{color:#28c840}.growth-stat-value--warning{color:#febc2e}.growth-stat-label{color:var(--text-muted);margin-top:2px;font-size:.7rem}.pricing{padding:80px 0}.pricing h2{text-align:center;letter-spacing:-.02em;margin-bottom:12px;font-size:clamp(1.6rem,4vw,2.2rem);font-weight:800}.pricing-sub{text-align:center;color:var(--text-muted);margin-bottom:48px;font-size:.9rem}.pricing-grid{grid-template-columns:repeat(2,1fr);gap:20px;max-width:680px;margin:0 auto;display:grid}@media (max-width:640px){.pricing-grid{grid-template-columns:1fr}}.pricing-card{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:32px;position:relative}.pricing-card.featured{background:linear-gradient(180deg,#ff6b350f 0%,var(--bg-card)100%);border-color:#ff6b3566}.pricing-badge{background:linear-gradient(135deg,var(--gradient-1),var(--gradient-2));border-radius:999px;padding:4px 12px;font-size:.7rem;font-weight:700;position:absolute;top:-10px;right:20px}.pricing-card h3{margin-bottom:4px;font-size:1.1rem;font-weight:700}.pricing-price{margin-bottom:4px;font-size:2.2rem;font-weight:800}.pricing-price small{color:var(--text-muted);font-size:.85rem;font-weight:500}.pricing-desc{color:var(--text-muted);margin-bottom:20px;font-size:.8rem}.pricing-features{flex-direction:column;gap:10px;margin-bottom:24px;list-style:none;display:flex}.pricing-features li{color:var(--text-muted);align-items:center;gap:8px;font-size:.85rem;display:flex}.pricing-features li:before{content:"✓";color:var(--accent);font-size:.8rem;font-weight:700}.pricing-btn{text-align:center;cursor:pointer;border:none;border-radius:12px;width:100%;padding:12px;font-size:.9rem;font-weight:600;text-decoration:none;transition:transform .2s,box-shadow .2s;display:block}.pricing-btn.outline{border:1px solid var(--border);color:var(--text);background:0 0}.pricing-btn.outline:hover{background:#ffffff08;border-color:#fff3}.pricing-btn.fill{background:linear-gradient(135deg,var(--gradient-1),var(--gradient-2));color:#fff}.pricing-btn.fill:hover{box-shadow:0 4px 20px var(--accent-glow);transform:translateY(-1px)}.cta{text-align:center;padding:100px 0;position:relative}.cta:before{content:"";background:radial-gradient(circle,var(--accent-glow)0%,transparent 70%);pointer-events:none;opacity:.3;width:500px;height:400px;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.cta h2{letter-spacing:-.02em;margin-bottom:16px;font-size:clamp(1.6rem,4vw,2.4rem);font-weight:800}.cta p{color:var(--text-muted);margin-bottom:32px;font-size:1rem}footer{border-top:1px solid var(--border);text-align:center;padding:40px 0}footer p{color:var(--text-muted);font-size:.75rem}footer a{color:var(--text-muted);text-underline-offset:2px;text-decoration:underline}footer a:hover{color:var(--text)}.footer-links{justify-content:center;gap:24px;margin-bottom:16px;display:flex}@keyframes fadeUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.animate{opacity:0;animation:.6s forwards fadeUp}.animate.d1{animation-delay:.1s}.animate.d2{animation-delay:.2s}.animate.d3{animation-delay:.3s}.animate.d4{animation-delay:.4s}.login-page{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{text-align:center;width:100%;max-width:400px}.login-logo{margin-bottom:32px;font-size:2rem;font-weight:800}.login-title{margin-bottom:12px;font-size:1.4rem;font-weight:700}.login-desc{color:var(--text-muted);margin-bottom:32px;font-size:.9rem;line-height:1.7}.login-btn{color:#333;cursor:pointer;background:#fff;border:none;border-radius:12px;justify-content:center;align-items:center;gap:10px;width:100%;padding:14px 24px;font-size:.95rem;font-weight:600;transition:transform .2s,box-shadow .2s;display:inline-flex}.login-btn:hover{transform:translateY(-1px);box-shadow:0 4px 20px #ffffff26}.login-error{color:#ff5f57;background:#ff5f571a;border:1px solid #ff5f574d;border-radius:10px;margin-top:16px;padding:10px 16px;font-size:.85rem}.login-terms{color:var(--text-muted);margin-top:24px;font-size:.75rem}.login-terms a{color:var(--text-muted);text-underline-offset:2px;text-decoration:underline}.login-terms a:hover{color:var(--text)}.app-shell{min-height:100vh}.app-main{max-width:1080px;margin:0 auto;padding:80px 24px 40px}.app-nav{z-index:100;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);background:#0a0a0bd9;padding:12px 0;position:fixed;top:0;left:0;right:0}.app-nav-inner{align-items:center;gap:32px;max-width:1080px;margin:0 auto;padding:0 24px;display:flex}.app-nav-logo{font-size:1.2rem;font-weight:800;text-decoration:none}.app-nav-links{flex:1;gap:4px;display:flex}.app-nav-link{color:var(--text-muted);border-radius:8px;padding:6px 14px;font-size:.85rem;font-weight:500;text-decoration:none;transition:color .2s,background .2s}.app-nav-link:hover{color:var(--text);background:#ffffff0a}.app-nav-link.active{color:var(--text);background:#ffffff0f}.app-nav-user{align-items:center;gap:12px;margin-left:auto;display:flex}.app-nav-avatar{border-radius:50%;width:28px;height:28px}.app-nav-avatar-placeholder{width:28px;height:28px;color:var(--accent);background:#ff6b3533;border-radius:50%;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex}.app-nav-logout{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;padding:4px 12px;font-size:.75rem;transition:border-color .2s,color .2s}.app-nav-logout:hover{color:var(--text);border-color:#fff3}.text-muted{color:var(--text-muted)}.upload-page{text-align:center;padding-top:80px}.upload-page h1{margin-bottom:12px;font-size:1.6rem;font-weight:700}.dropzone{border:2px dashed var(--border);border-radius:var(--radius);text-align:center;cursor:pointer;max-width:480px;margin:40px auto 0;padding:48px 32px;transition:border-color .2s,background .2s}.dropzone:hover,.dropzone.dragging{border-color:var(--accent);background:#ff6b350a}.dropzone.disabled{opacity:.5;pointer-events:none}.dropzone svg{color:var(--text-muted);margin-bottom:16px}.dropzone-text{color:var(--text-muted);margin-bottom:16px;font-size:.9rem}.dropzone-text span{font-size:.8rem}.dropzone-btn{background:linear-gradient(135deg,var(--gradient-1),var(--gradient-2));color:#fff;cursor:pointer;border-radius:10px;padding:10px 24px;font-size:.85rem;font-weight:600;transition:transform .2s,box-shadow .2s;display:inline-block}.dropzone-btn:hover{box-shadow:0 4px 16px var(--accent-glow);transform:translateY(-1px)}.dropzone-hint{color:var(--text-muted);margin-top:12px;font-size:.75rem}.upload-active{max-width:600px;margin:40px auto 0}.upload-preview{border-radius:var(--radius);border:1px solid var(--border);margin-bottom:20px;overflow:hidden}.upload-preview img{object-fit:contain;background:#111;width:100%;max-height:400px;display:block}.upload-progress-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);text-align:center;padding:32px;transition:border-color .3s}.upload-spinner{justify-content:center;margin-bottom:16px;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.upload-status{color:var(--text-muted);font-size:.9rem}.upload-preview-score{margin-top:16px;font-size:2.4rem;font-weight:800}.upload-preview-score .score-label{color:var(--text-muted);font-size:1rem}.upload-error{color:#ff5f57;margin-top:12px;font-size:.85rem}.upload-error-banner{text-align:center;background:#ff5f5714;border:1px solid #ff5f5740;border-radius:12px;max-width:480px;margin:24px auto 0;padding:16px 20px}.upload-error-banner p{color:#ff5f57;margin-bottom:12px;font-size:.9rem;line-height:1.6}.upload-error-banner button{color:#ff5f57;cursor:pointer;background:#ff5f5726;border:1px solid #ff5f574d;border-radius:8px;padding:8px 20px;font-size:.85rem;font-weight:600;transition:background .2s}.upload-error-banner button:hover{background:#ff5f5740}.review-page{max-width:800px;margin:0 auto}.review-header{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:32px;margin-bottom:24px;padding:32px;transition:border-color .3s;display:flex}.review-header:hover{border-color:#ff6b3533}@media (max-width:640px){.review-header{text-align:center;flex-direction:column}}.score-ring-large{flex-shrink:0;position:relative}.score-ring-value{text-align:center;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.score-ring-value .gradient-text{font-size:2.4rem;font-weight:800;display:block}.score-ring-grade{color:var(--text-muted);font-size:.8rem}.score-breakdown{flex-direction:column;flex:1;gap:12px;width:100%;display:flex}.score-breakdown-header{align-items:center;gap:8px;margin-bottom:4px;display:flex}.score-breakdown-icon{font-size:.85rem}.score-breakdown-label{color:var(--text-muted);flex:1;font-size:.85rem}.score-breakdown-value{font-size:.9rem;font-weight:700}.score-bar-track{background:#ffffff0a;border-radius:3px;height:6px;overflow:hidden}.score-bar-fill{border-radius:3px;height:100%;transition:width 1s}.review-feedback{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:24px;padding:28px;transition:border-color .3s}.review-feedback:hover{border-color:#ff6b3533}.review-summary{border-bottom:1px solid var(--border);margin-bottom:24px;padding-bottom:20px;font-size:1rem;line-height:1.8}.feedback-sections{flex-direction:column;gap:20px;display:flex}.feedback-section h3{align-items:center;gap:8px;margin-bottom:10px;font-size:.95rem;font-weight:700;display:flex}.feedback-icon{font-size:.9rem}.feedback-icon.good{color:#28c840}.feedback-icon.improve{color:#ff5f57}.feedback-section ul{flex-direction:column;gap:6px;list-style:none;display:flex}.feedback-section li{color:var(--text-muted);padding-left:16px;font-size:.85rem;line-height:1.7;position:relative}.feedback-section li:before{content:"";background:var(--text-muted);border-radius:50%;width:5px;height:5px;position:absolute;top:10px;left:0}.feedback-section.tip{background:#ff6b350f;border:1px solid #ff6b3526;border-radius:12px;padding:16px 20px}.review-images{flex-direction:column;gap:24px;display:flex}.composition-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:border-color .3s;overflow:hidden}.composition-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.composition-header h3{font-size:.95rem;font-weight:600}.composition-toggle{color:var(--accent);cursor:pointer;background:#ff6b351a;border:1px solid #ff6b3533;border-radius:6px;padding:4px 12px;font-size:.75rem;font-weight:600}.composition-wrapper{background:#111}.composition-canvas{width:100%;display:block}.composition-legend{border-top:1px solid var(--border);color:var(--text-muted);flex-wrap:wrap;gap:16px;padding:12px 20px;font-size:.75rem;display:flex}.legend-item{align-items:center;gap:6px;display:flex}.legend-color{border-radius:2px;flex-shrink:0;width:12px;height:3px}.before-after-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:border-color .3s;overflow:hidden}.before-after-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.before-after-header h3{font-size:.95rem;font-weight:600}.before-after-tabs{gap:4px;display:flex}.ba-tab{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;padding:4px 12px;font-size:.75rem;font-weight:600;transition:all .2s}.ba-tab.active{color:var(--accent);background:#ff6b351a;border-color:#ff6b354d}.before-after-image{background:#111;position:relative}.before-after-image img{object-fit:contain;width:100%;max-height:500px;display:block}.before-after-label{letter-spacing:.06em;color:var(--accent);background:#000000b3;border-radius:6px;padding:4px 10px;font-size:.7rem;font-weight:700;position:absolute;top:12px;left:12px}.before-after-controls{align-items:center;gap:8px;display:flex}.before-after-canvas{width:100%;display:block}.composition-notes{border-top:1px solid var(--border);flex-direction:column;gap:0;display:flex}.composition-note{color:var(--text-muted);border-bottom:1px solid var(--border);align-items:flex-start;gap:10px;padding:10px 20px;font-size:.8rem;line-height:1.6;display:flex}.composition-note:last-child{border-bottom:none}.composition-note-color{border-radius:3px;flex-shrink:0;width:12px;height:12px;margin-top:2px}.composition-note strong{color:var(--text);margin-bottom:2px;font-size:.8rem;display:block}.before-after-explanation{color:var(--text-muted);border-top:1px solid var(--border);align-items:flex-start;gap:10px;padding:14px 20px;font-size:.85rem;line-height:1.7;display:flex}.before-after-explanation-icon{color:var(--accent);background:#ff6b351a;border-radius:4px;flex-shrink:0;padding:2px 6px;font-size:.8rem;font-weight:700}.history-page{max-width:800px;margin:0 auto}.history-page h1{margin-bottom:24px;font-size:1.6rem;font-weight:700}.history-empty{text-align:center;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:60px 20px}.history-empty p{color:var(--text-muted);margin-bottom:20px}.history-cta{background:linear-gradient(135deg,var(--gradient-1),var(--gradient-2));color:#fff;border-radius:10px;padding:10px 24px;font-size:.85rem;font-weight:600;text-decoration:none;display:inline-block}.history-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.review-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);text-decoration:none;transition:border-color .2s,transform .2s;overflow:hidden}.review-card:hover{border-color:#ff6b354d;transform:translateY(-2px)}.review-card-thumb{aspect-ratio:4/3;background:#111;overflow:hidden}.review-card-thumb img{object-fit:cover;width:100%;height:100%}.review-card-info{padding:12px 16px}.review-card-score{margin-bottom:4px}.review-card-score .gradient-text{font-size:1.4rem;font-weight:800}.review-card-max{color:var(--text-muted);font-size:.8rem}.review-card-scores-mini{color:var(--text-muted);gap:8px;margin-bottom:6px;font-size:.7rem;display:flex}.review-card-date{color:var(--text-muted);font-size:.7rem}.dashboard-page{max-width:800px;margin:0 auto}.dashboard-page h1{margin-bottom:24px;font-size:1.6rem;font-weight:700}.dashboard-empty{text-align:center;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:60px 20px}.dashboard-empty p{color:var(--text-muted);margin-bottom:20px}.dashboard-stats{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px;display:grid}@media (max-width:640px){.dashboard-stats{grid-template-columns:repeat(2,1fr)}}.dash-stat{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);text-align:center;padding:20px;transition:border-color .3s}.dash-stat:hover{border-color:#ff6b3533}.dash-stat-value{margin-bottom:4px;font-size:1.4rem;font-weight:800}.dash-stat-value.up{color:#28c840}.dash-stat-value.warning{color:#febc2e}.dash-stat-label{color:var(--text-muted);font-size:.75rem}.score-chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;transition:border-color .3s}.score-chart-card:hover{border-color:#ff6b3533}.score-chart-header{justify-content:space-between;align-items:baseline;margin-bottom:20px;display:flex}.score-chart-title{font-size:.9rem;font-weight:600}.score-chart-period{color:var(--text-muted);font-size:.75rem}.score-chart-bars{align-items:flex-end;gap:8px;display:flex}.score-chart-bar-group{flex-direction:column;flex:1;align-items:center;display:flex}.score-chart-score{margin-bottom:6px;font-size:.7rem;font-weight:700}.score-chart-score.highlight{color:var(--accent)}.score-chart-bar{background:linear-gradient(180deg,var(--gradient-1),var(--gradient-2));border-radius:4px 4px 0 0;width:100%;min-height:4px}.score-chart-label{color:var(--text-muted);margin-top:6px;font-size:.6rem}.review-share{text-align:center;margin-top:24px}.share-actions{justify-content:center;gap:12px;display:flex}.share-btn{background:var(--bg-card);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:10px;padding:10px 24px;font-size:.85rem;font-weight:600;transition:border-color .2s,background .2s}.share-btn:hover{background:var(--bg-card-hover);border-color:#fff3}.share-btn.twitter{background:linear-gradient(135deg,var(--gradient-1),var(--gradient-2));color:#fff;border:none}.share-btn.twitter:hover{opacity:.9}.share-page{max-width:680px;min-height:100vh;margin:0 auto;padding:40px 24px}.share-header{text-align:center;margin-bottom:32px}.share-logo{font-size:1.6rem;font-weight:800}.share-tagline{color:var(--text-muted);margin-top:4px;font-size:.8rem}.share-content{flex-direction:column;gap:24px;display:flex}.share-images{grid-template-columns:1fr 1fr;gap:12px;display:grid}@media (max-width:480px){.share-images{grid-template-columns:1fr}}.share-image{border-radius:var(--radius);border:1px solid var(--border);background:#111;position:relative;overflow:hidden}.share-image img{aspect-ratio:4/3;object-fit:cover;width:100%;display:block}.share-image-label{letter-spacing:.06em;color:var(--text-muted);background:#000000b3;border-radius:4px;padding:3px 8px;font-size:.65rem;font-weight:700;position:absolute;top:8px;left:8px}.share-image-label.accent{color:var(--accent)}.share-score-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);text-align:center;padding:24px}.share-score{margin-bottom:12px}.share-score .gradient-text{font-size:3rem;font-weight:800}.share-score-max{color:var(--text-muted);font-size:1rem}.share-scores-detail{color:var(--text-muted);justify-content:center;gap:20px;margin-bottom:16px;font-size:.85rem;display:flex}.share-scores-detail strong{color:var(--text)}.share-review-text{color:var(--text-muted);font-size:.9rem;line-height:1.7}.share-cta-section{text-align:center;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:32px}.share-cta-section p{color:var(--text-muted);margin-bottom:16px;font-size:.9rem}.share-cta-btn{background:linear-gradient(135deg,var(--gradient-1),var(--gradient-2));color:#fff;border-radius:10px;padding:12px 28px;font-size:.9rem;font-weight:600;text-decoration:none;transition:transform .2s,box-shadow .2s;display:inline-block}.share-cta-btn:hover{box-shadow:0 4px 20px var(--accent-glow);transform:translateY(-1px)}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}
