:root{--ink:#111413;--muted:#68706c;--line:#dce2de;--paper:#f4f6f2;--white:#fff;--green:#1f6b4f;--green-dark:#174f3c;--lime:#d9f99d;--orange:#ff6b35;--shadow:0 24px 60px #17261f1a}*{box-sizing:border-box}html{scroll-behavior:smooth}body{color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased;margin:0;font-family:Arial,Noto Sans Thai,sans-serif}a{color:inherit;text-decoration:none}button{font:inherit}.brand{letter-spacing:-.03em;align-items:center;gap:10px;font-weight:800;display:inline-flex}.brand-mark{color:#fff;background:var(--green);border-radius:12px;place-items:center;width:38px;height:38px;display:grid}.landing-shell{min-height:100vh;padding:0 5vw 64px;overflow:hidden}.landing-nav{justify-content:space-between;align-items:center;max-width:1240px;height:82px;margin:0 auto;display:flex}.hero{max-width:1120px;margin:0 auto;padding:108px 0 96px;position:relative}.hero:before{z-index:-1;width:520px;height:520px;box-shadow:inset 0 0 0 88px var(--paper), inset 0 0 0 89px #c7d1cb;content:"";border:1px solid #c7d1cb;border-radius:50%;position:absolute;top:12px;right:-170px}.eyebrow{color:var(--green);letter-spacing:.16em;margin:0 0 18px;font-size:12px;font-weight:800}.hero h1{letter-spacing:-.065em;max-width:800px;margin:0;font-size:clamp(52px,7vw,96px);line-height:.98}.hero>p:not(.eyebrow){max-width:610px;color:var(--muted);margin:34px 0;font-size:20px;line-height:1.75}.hero-actions{flex-wrap:wrap;gap:12px;display:flex}.button{border-radius:999px;justify-content:center;align-items:center;min-height:48px;padding:0 22px;font-size:14px;font-weight:750;display:inline-flex}.button-primary{color:#fff;background:var(--green)}.button-secondary{border:1px solid var(--line);background:var(--white)}.button-ghost{border:1px solid var(--ink)}.module-preview{border-top:1px solid var(--line);border-left:1px solid var(--line);grid-template-columns:repeat(3,1fr);max-width:1240px;margin:0 auto;display:grid}.module-preview article{border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:#ffffff73;min-height:270px;padding:34px}.module-code{color:var(--green);font-size:12px;font-weight:800}.module-preview h2{letter-spacing:-.04em;margin:50px 0 12px;font-size:34px}.module-preview p{min-height:52px;color:var(--muted);line-height:1.65}.status{color:var(--muted);background:#e7ebe8;border-radius:999px;padding:7px 11px;font-size:12px;font-weight:700;display:inline-flex}.status-live{color:var(--green-dark);background:var(--lime)}.auth-shell{background:linear-gradient(135deg, #1f6b4ff5, #10261dfa), var(--green);place-items:center;min-height:100vh;padding:24px;display:grid}.auth-card{background:var(--white);width:min(100%,490px);box-shadow:var(--shadow);border-radius:30px;padding:54px}.auth-brand{margin-bottom:70px}.auth-card h1{letter-spacing:-.05em;margin:0 0 18px;font-size:42px;line-height:1.12}.auth-copy{color:var(--muted);margin-bottom:34px;line-height:1.75}.google-button{border:1px solid var(--line);width:100%;min-height:56px;color:var(--ink);cursor:pointer;background:#fff;border-radius:14px;justify-content:center;align-items:center;gap:14px;padding:0 20px;font-weight:750;display:flex}.google-button:hover{border-color:var(--green)}.google-mark{color:#4285f4;font-size:20px;font-weight:900}.auth-note{color:#8b928e;text-align:center;margin:20px 0 0;font-size:11px}.portal-shell{grid-template-columns:260px 1fr;min-height:100vh;display:grid}.sidebar{color:#fff;background:#11271f;flex-direction:column;height:100vh;padding:28px 22px;display:flex;position:sticky;top:0}.sidebar-brand{margin-bottom:58px;font-size:22px}.sidebar-label{color:#89a399;letter-spacing:.14em;text-transform:uppercase;margin:0 12px 10px;font-size:10px;font-weight:800}.nav-item{color:#abc0b7;border-radius:12px;padding:13px 14px;font-size:14px;font-weight:700}.nav-item-active{color:#fff;background:#ffffff17}.sidebar-spacer{flex:1}.profile{border-top:1px solid #ffffff1f;align-items:center;gap:11px;min-width:0;padding:16px 0;display:flex}.profile>div:last-child{min-width:0}.profile strong,.profile span{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.profile strong{font-size:13px}.profile span{color:#89a399;margin-top:3px;font-size:11px}.avatar{width:38px;height:38px;color:var(--green-dark);background:var(--lime);border-radius:50%;flex:0 0 38px;place-items:center;font-weight:850;display:grid}.sign-out{color:#89a399;cursor:pointer;text-align:left;background:0 0;border:0;padding:10px;font-size:12px}.portal-content{padding:56px clamp(30px,6vw,96px)}.portal-header{justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:78px;display:flex}.portal-header h1{letter-spacing:-.055em;margin:0;font-size:clamp(40px,5vw,70px)}.tenant-switcher{border:1px solid var(--line);background:#ffffffb3;border-radius:14px;gap:5px;min-width:230px;padding:15px 18px;display:grid}.tenant-switcher label{color:var(--muted);font-size:10px}.tenant-switcher>div{gap:8px;display:flex}.tenant-switcher select,.workspace-form input{border:1px solid var(--line);min-width:0;color:var(--ink);background:#fff;border-radius:10px;outline:none}.tenant-switcher select{width:100%;padding:9px 10px;font-size:13px;font-weight:700}.tenant-switcher button,.workspace-form button{color:#fff;background:var(--green);cursor:pointer;border:0;border-radius:10px;font-weight:750}.tenant-switcher button{padding:0 13px;font-size:12px}.portal-alert{color:#8c3519;background:#fff3ee;border:1px solid #f2c6b5;border-radius:12px;margin:-52px 0 32px;padding:12px 16px;font-size:13px}.portal-success{color:var(--green-dark);background:#eefaf3;border:1px solid #b9ddcb;border-radius:12px;margin-bottom:28px;padding:12px 16px;font-size:13px}.section-heading{justify-content:space-between;align-items:flex-end;margin-bottom:24px;display:flex}.section-heading h2{letter-spacing:-.04em;margin:0;font-size:30px}.section-heading>span{color:var(--muted);font-size:12px}.portal-modules{grid-template-columns:repeat(3,minmax(220px,1fr));gap:18px;display:grid}.portal-module-card{border:1px solid var(--line);background:var(--white);border-radius:22px;flex-direction:column;min-height:300px;padding:26px;transition:transform .16s,box-shadow .16s;display:flex}.portal-module-card:hover{box-shadow:var(--shadow);transform:translateY(-4px)}.portal-module-top{justify-content:space-between;align-items:flex-start;display:flex}.module-icon{width:54px;height:54px;color:var(--green-dark);background:var(--lime);border-radius:16px;place-items:center;font-size:12px;font-weight:850;display:grid}.launch-arrow{font-size:24px}.portal-module-card h3{letter-spacing:-.04em;margin:48px 0 8px;font-size:28px}.portal-module-card p{color:var(--muted);margin:0;line-height:1.65}.module-ready{color:var(--green);margin-top:auto;font-size:11px;font-weight:800}.empty-state{background:#ffffff80;border:1px dashed #b9c5be;border-radius:24px;max-width:720px;padding:52px}.empty-state>span{color:var(--orange);font-size:12px;font-weight:800}.empty-state h2{letter-spacing:-.04em;margin:18px 0 12px;font-size:34px}.empty-state p{color:var(--muted);margin:0;line-height:1.7}.admin-shell{min-height:100vh;padding:54px clamp(24px,6vw,90px) 80px}.admin-header{justify-content:space-between;align-items:flex-end;gap:24px;max-width:1280px;margin:0 auto 48px;display:flex}.admin-header h1{letter-spacing:-.055em;margin:0;font-size:clamp(42px,6vw,76px)}.admin-back{color:var(--muted);margin-bottom:42px;font-size:13px;font-weight:700;display:inline-flex}.admin-role,.role-badge{text-transform:uppercase;letter-spacing:.08em;border-radius:999px;font-size:10px;font-weight:850}.admin-role{color:var(--green-dark);background:var(--lime);padding:10px 14px}.admin-shell>.portal-alert,.admin-shell>.portal-success{max-width:1280px;margin-left:auto;margin-right:auto}.admin-grid{grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);gap:22px;max-width:1280px;margin:0 auto;display:grid}.admin-panel{border:1px solid var(--line);background:#fff;border-radius:24px;padding:30px}.admin-panel-heading{justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:26px;display:flex}.admin-panel-heading h2{letter-spacing:-.04em;margin:0;font-size:28px}.admin-panel-heading>span{color:var(--muted);font-size:11px}.invite-form{border-bottom:1px solid var(--line);grid-template-columns:minmax(0,1fr) 120px auto;gap:8px;padding-bottom:26px;display:grid}.invite-form input,.invite-form select{border:1px solid var(--line);min-height:44px;color:var(--ink);background:#fff;border-radius:10px;padding:0 12px}.invite-form button{color:#fff;background:var(--green);cursor:pointer;border:0;border-radius:10px;padding:0 16px;font-weight:750}.member-list,.module-admin-list{display:grid}.member-row,.module-admin-row{border-bottom:1px solid var(--line);align-items:center;gap:12px;padding:18px 0;display:flex}.member-row:last-child,.module-admin-row:last-child{border-bottom:0}.member-row>div:nth-child(2),.module-admin-row>div{flex:1;min-width:0}.member-row strong,.member-row span,.module-admin-row strong,.module-admin-row span{display:block}.member-row strong,.module-admin-row strong{font-size:13px}.member-row>div:nth-child(2) span,.module-admin-row>div span{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;margin-top:4px;font-size:11px;overflow:hidden}.member-row-pending{opacity:.72}.role-badge{color:var(--green);background:#edf5f0;padding:7px 9px}.module-admin-row{justify-content:space-between}.module-toggle{border:1px solid var(--line);min-width:88px;color:var(--muted);cursor:pointer;background:#f4f6f4;border-radius:999px;padding:9px 12px;font-size:11px;font-weight:800}.module-toggle-on{color:var(--green-dark);background:var(--lime);border-color:#b8dc9b}.workspace-form{gap:9px;margin-top:34px;display:grid}.workspace-form label{font-size:12px;font-weight:750}.workspace-form>div{gap:10px;display:flex}.workspace-form input{flex:1;min-height:48px;padding:0 15px}.workspace-form input:focus,.tenant-switcher select:focus{border-color:var(--green);box-shadow:0 0 0 3px #1f6b4f1a}.workspace-form button{padding:0 20px}@media (max-width:900px){.module-preview,.portal-modules,.portal-shell{grid-template-columns:1fr}.sidebar{height:auto;position:static}.sidebar-label,.nav-item,.sidebar-spacer{display:none}.sidebar-brand{margin-bottom:20px}.portal-header{flex-direction:column;margin-bottom:50px}.tenant-switcher{width:100%}.admin-grid{grid-template-columns:1fr}}@media (max-width:600px){.hero{padding:70px 0}.hero:before{display:none}.hero h1{font-size:52px}.auth-card{padding:34px 26px}.auth-brand{margin-bottom:50px}.portal-content{padding:38px 22px}.workspace-form>div{flex-direction:column}.workspace-form button{min-height:48px}.admin-header{flex-direction:column;align-items:flex-start}.invite-form{grid-template-columns:1fr}.invite-form button{min-height:44px}}
