:root{
  --bg:#090a12;--bg2:#111429;--text:#f7f7fb;--muted:#9aa1b8;--soft:#e9ecf8;--line:rgba(255,255,255,.11);
  --card:rgba(255,255,255,.075);--card2:rgba(255,255,255,.045);--shadow:0 26px 90px rgba(12,13,25,.28);
  --ig-pink:#fd1d6d;--ig-orange:#fcb045;--ig-purple:#833ab4;--ig-blue:#405de6;--ig-red:#e1306c;--ig-yellow:#feda75;
  --accent-gradient:linear-gradient(135deg,#feda75 0%,#fa7e1e 22%,#d62976 48%,#962fbf 72%,#4f5bd5 100%);
  --radius:26px;--radius2:18px;--max:1180px;
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-height:100vh;background:radial-gradient(circle at 12% -5%,rgba(214,41,118,.25),transparent 32%),radial-gradient(circle at 88% 0%,rgba(79,91,213,.22),transparent 32%),linear-gradient(180deg,#080914 0%,#10101d 48%,#07070d 100%);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}img,video{max-width:100%;display:block}button{cursor:pointer}.container{width:min(var(--max),calc(100% - 32px));margin:0 auto}.site-header{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px clamp(16px,4vw,44px);background:rgba(8,9,20,.72);border-bottom:1px solid var(--line);backdrop-filter:blur(18px)}.brand{display:flex;align-items:center;gap:12px;font-weight:900;letter-spacing:-.04em}.brand-mark{width:40px;height:40px;border-radius:14px;background:var(--accent-gradient);display:grid;place-items:center;box-shadow:0 14px 34px rgba(214,41,118,.28)}.brand-mark span{width:21px;height:21px;border-radius:7px;border:3px solid #fff;position:relative}.brand-mark span:after{content:"";position:absolute;right:-8px;top:-8px;width:8px;height:8px;border-radius:50%;background:#fff}.brand-text{font-size:1.2rem}.site-nav{display:flex;align-items:center;gap:18px;color:#d9dcea;font-size:.95rem}.site-nav a:hover{color:#fff}.nav-toggle{display:none;background:transparent;border:0;color:#fff;font-size:1.45rem}.nav-pill,.btn{border:1px solid var(--line);border-radius:999px;padding:11px 17px;background:rgba(255,255,255,.065);color:#fff;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:43px;transition:.18s ease;white-space:nowrap}.nav-pill,.btn-instagram{background:var(--accent-gradient);border:0;color:#fff;font-weight:850;box-shadow:0 16px 38px rgba(214,41,118,.24)}.btn-instagram:hover,.nav-pill:hover,.btn:hover{transform:translateY(-1px)}.btn-primary{background:var(--accent-gradient);border:0;color:#fff;font-weight:850}.btn-ghost{background:rgba(255,255,255,.07)}.btn-ghost-light{background:#fff;color:#14151f;border:0;font-weight:800}.btn-danger{background:rgba(225,48,108,.12);border-color:rgba(225,48,108,.38);color:#ffd5e3}.btn-small{padding:7px 11px;min-height:34px;font-size:.86rem}.btn.full{width:100%}.hero{padding:78px 0 46px}.hero-grid{display:grid;grid-template-columns:1.03fr .97fr;gap:42px;align-items:center}.hero-copy{max-width:710px}.eyebrow,.mini-label{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.13);color:#eff1ff;font-weight:750;font-size:.88rem}.mini-label{font-size:.78rem;text-transform:uppercase;letter-spacing:.09em;color:#676b7b;background:#f3f4f8;border-color:#eceef4}.mini-label.light{color:#fff;background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.18)}.ig-dot{width:9px;height:9px;border-radius:50%;background:var(--accent-gradient);box-shadow:0 0 20px rgba(225,48,108,.75)}h1{font-size:clamp(2.65rem,6.4vw,6rem);line-height:.91;letter-spacing:-.082em;margin:18px 0 20px}.hero p.lead{font-size:clamp(1.05rem,2vw,1.3rem);line-height:1.65;color:#d0d4e7;max-width:690px}.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}.trust-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:30px}.trust-row div{padding:15px;border-radius:20px;background:rgba(255,255,255,.075);border:1px solid rgba(255,255,255,.12)}.trust-row strong{display:block;font-size:.98rem}.trust-row span{display:block;color:#b4bacd;font-size:.84rem;margin-top:4px}.hero-visual{position:relative;min-height:650px;display:grid;place-items:center}.floating-card{position:absolute;z-index:4;padding:14px 16px;border-radius:19px;background:rgba(255,255,255,.92);color:#14151f;box-shadow:0 22px 60px rgba(0,0,0,.18);border:1px solid rgba(255,255,255,.6);backdrop-filter:blur(10px)}.floating-card b{display:block}.floating-card span{display:block;color:#676b7b;font-size:.83rem;margin-top:3px}.card-upload{left:0;top:82px}.card-share{right:0;bottom:92px}.phone-shell{width:min(410px,100%);border-radius:48px;padding:13px;background:#111;box-shadow:0 44px 110px rgba(0,0,0,.38),0 0 0 1px rgba(255,255,255,.16);position:relative}.phone-speaker{position:absolute;top:9px;left:50%;transform:translateX(-50%);width:92px;height:6px;border-radius:999px;background:#2b2b2b;z-index:2}.instagram-mock,.instagram-preview{background:#fff;color:#111;border-radius:37px;overflow:hidden;min-height:620px}.instagram-mock{padding:20px 0 0}.ig-topbar{height:44px;display:flex;align-items:center;justify-content:space-between;padding:0 18px;border-bottom:1px solid #f0f0f0;font-size:.98rem}.ig-icons{letter-spacing:4px}.ig-profile-line{display:grid;grid-template-columns:86px repeat(3,1fr);align-items:center;padding:14px 16px 8px;gap:8px}.ig-avatar-ring{width:76px;height:76px;border-radius:50%;padding:3px;background:var(--accent-gradient)}.ig-avatar-demo{width:100%;height:100%;border-radius:50%;background:radial-gradient(circle at 35% 30%,#fff 0 9%,transparent 10%),linear-gradient(135deg,#111827,#334155);border:3px solid #fff}.ig-stats{text-align:center}.ig-stats b{display:block;font-size:1rem}.ig-stats span{display:block;font-size:.72rem;color:#333}.ig-bio{display:grid;gap:2px;padding:0 18px 10px;font-size:.84rem}.ig-bio em{font-style:normal;color:#255dcf}.ig-buttons{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:0 16px 12px}.ig-buttons span{background:#efefef;border-radius:8px;text-align:center;padding:7px 8px;font-weight:800;font-size:.8rem}.ig-stories-demo{display:flex;gap:15px;overflow:hidden;padding:2px 16px 10px}.ig-stories-demo span{display:grid;justify-items:center;font-size:.68rem;color:#222;min-width:54px}.ig-stories-demo i{width:52px;height:52px;border-radius:50%;padding:3px;background:var(--accent-gradient);display:block;margin-bottom:4px}.ig-tabs-demo{display:grid;grid-template-columns:repeat(3,1fr);height:36px;border-top:1px solid #eee;border-bottom:1px solid #ddd;align-items:center;text-align:center}.ig-tabs-demo b:first-child{border-bottom:2px solid #111;height:36px;display:grid;place-items:center}.ig-grid-demo{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:#fff}.ig-grid-demo i,.mini-phone-grid span{aspect-ratio:1/1;display:block;background:#ddd}.demo-tile-1{background:linear-gradient(135deg,#fb7185,#fde68a)}.demo-tile-2{background:linear-gradient(135deg,#111827,#64748b)}.demo-tile-3{background:linear-gradient(135deg,#8b5cf6,#ec4899)}.demo-tile-4{background:linear-gradient(135deg,#06b6d4,#dbeafe)}.demo-tile-5{background:linear-gradient(135deg,#f97316,#fef3c7)}.demo-tile-6{background:linear-gradient(135deg,#1e293b,#94a3b8)}.demo-tile-7{background:linear-gradient(135deg,#22c55e,#bbf7d0)}.demo-tile-8{background:linear-gradient(135deg,#f43f5e,#581c87)}.demo-tile-9{background:linear-gradient(135deg,#0f172a,#38bdf8)}.demo-tile-10{background:linear-gradient(135deg,#facc15,#f97316)}.demo-tile-11{background:linear-gradient(135deg,#6d28d9,#f0abfc)}.demo-tile-12{background:linear-gradient(135deg,#0f172a,#e2e8f0)}.section{padding:70px 0}.white-section{background:#fff;color:#111827}.section-title{max-width:780px;margin-bottom:28px}.section-title.center{text-align:center;margin-left:auto;margin-right:auto}.section-title h2{font-size:clamp(2rem,4vw,3.6rem);letter-spacing:-.065em;line-height:.98;margin:14px 0 12px}.section-title p{color:#687083;line-height:1.7;font-size:1.02rem}.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.feature-card,.panel,.auth-card,.project-card,.admin-card{background:linear-gradient(180deg,var(--card),var(--card2));border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 18px 60px rgba(0,0,0,.14)}.clean-card{background:#fff;border:1px solid #edf0f5;box-shadow:0 18px 55px rgba(24,28,45,.08);padding:24px;color:#111827}.feature-icon{width:46px;height:46px;border-radius:16px;display:grid;place-items:center;font-weight:900;margin-bottom:14px}.gradient-icon{background:var(--accent-gradient);color:#fff}.feature-card h3{margin:0 0 9px;font-size:1.13rem}.feature-card p{margin:0;color:#687083;line-height:1.6}.product-story{background:linear-gradient(180deg,#fafbff,#eef1f8);color:#111827}.story-grid{display:grid;grid-template-columns:.86fr 1.14fr;gap:34px;align-items:start}.workflow-board{display:grid;gap:14px}.workflow-step{display:grid;grid-template-columns:54px 1fr;gap:12px;padding:20px;border-radius:22px;background:#fff;border:1px solid #e9edf5;box-shadow:0 18px 45px rgba(25,31,48,.07)}.workflow-step span{width:42px;height:42px;border-radius:50%;background:#f1f3f7;color:#111827;font-weight:900;display:grid;place-items:center}.workflow-step.active span{background:var(--accent-gradient);color:#fff}.workflow-step h3{margin:0 0 6px}.workflow-step p{margin:0;color:#687083;line-height:1.55}.dark-demo-section{background:radial-gradient(circle at 18% 15%,rgba(225,48,108,.22),transparent 32%),#070812}.split-demo{display:grid;grid-template-columns:.85fr 1.15fr;align-items:center;gap:44px}.split-demo h2{font-size:clamp(2.1rem,4vw,4rem);letter-spacing:-.07em;line-height:.96;margin:14px 0}.split-demo p{color:#c7ccdd;line-height:1.75;font-size:1.08rem;max-width:620px}.mini-phone-stack{height:420px;position:relative}.mini-phone{position:absolute;width:245px;height:390px;border-radius:38px;background:#111;padding:13px;box-shadow:0 34px 90px rgba(0,0,0,.35)}.mini-phone.back{left:18px;top:24px;transform:rotate(-8deg);background:linear-gradient(135deg,#1f2937,#111827)}.mini-phone.front{left:128px;top:0;transform:rotate(5deg);background:#111}.mini-phone-grid{height:100%;border-radius:28px;background:#fff;padding:70px 8px 8px;display:grid;grid-template-columns:repeat(3,1fr);align-content:start;gap:3px}.mini-phone-grid span:nth-child(3n+1){background:linear-gradient(135deg,#fb7185,#fde68a)}.mini-phone-grid span:nth-child(3n+2){background:linear-gradient(135deg,#111827,#94a3b8)}.mini-phone-grid span:nth-child(3n){background:linear-gradient(135deg,#8b5cf6,#ec4899)}.instagram-cta{margin:0 auto;padding:36px;border-radius:32px;background:linear-gradient(135deg,rgba(254,218,117,.12),rgba(214,41,118,.15),rgba(79,91,213,.16));border:1px solid rgba(255,255,255,.13);display:flex;align-items:center;justify-content:space-between;gap:24px}.instagram-cta h2{font-size:clamp(2rem,4vw,3.4rem);line-height:1;letter-spacing:-.06em;margin:12px 0}.instagram-cta p{color:#c5cad8;line-height:1.65}.site-footer{display:flex;justify-content:space-between;gap:20px;padding:34px clamp(16px,4vw,44px);border-top:1px solid var(--line);color:#aeb4c8;background:#06070d}.site-footer strong{color:#fff}.footer-links{display:flex;gap:16px;flex-wrap:wrap}.auth-wrap{min-height:calc(100vh - 170px);display:grid;place-items:center;padding:44px 16px}.auth-card{width:min(520px,100%);padding:28px}.auth-card h1,.page-title h1{font-size:clamp(2rem,5vw,3.7rem);line-height:.98;letter-spacing:-.065em;margin:10px 0 12px}.auth-card p,.page-title p{color:#c3c8d8;line-height:1.6}.form-grid{display:grid;gap:14px}.compact-form{gap:12px}.field label{display:block;margin-bottom:7px;color:#eef1fb;font-weight:700;font-size:.92rem}.input,textarea,select{width:100%;border:1px solid rgba(255,255,255,.13);border-radius:15px;background:rgba(6,8,18,.74);color:#fff;padding:13px 14px;outline:none}.input:focus,textarea:focus,select:focus{border-color:rgba(225,48,108,.72);box-shadow:0 0 0 4px rgba(225,48,108,.1)}textarea{min-height:100px;resize:vertical}.form-help{font-size:.9rem;color:#b8bfd1;line-height:1.55}.flash{width:min(var(--max),calc(100% - 32px));margin:16px auto 0;padding:13px 16px;border-radius:16px;border:1px solid var(--line);background:rgba(255,255,255,.08)}.flash-success{border-color:rgba(34,197,94,.34);background:rgba(34,197,94,.1)}.flash-error{border-color:rgba(225,48,108,.4);background:rgba(225,48,108,.1)}.flash-info{border-color:rgba(79,91,213,.36);background:rgba(79,91,213,.11)}.app-shell{width:min(1380px,calc(100% - 24px));margin:26px auto 58px}.top-row{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:20px}.top-actions{display:flex;gap:10px;flex-wrap:wrap}.dashboard-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.project-card{padding:18px}.project-card-top{display:flex;align-items:center;gap:12px}.avatar-sm{width:50px;height:50px;border-radius:17px;background:var(--accent-gradient);display:grid;place-items:center;overflow:hidden;flex:none;color:#fff;font-weight:900}.avatar-sm img{width:100%;height:100%;object-fit:cover}.project-card h3{margin:0;font-size:1.1rem}.project-card p{margin:3px 0 0;color:#b8bfd1;font-size:.9rem}.badge{margin-left:auto;padding:7px 10px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid var(--line);font-size:.76rem;color:#f5f6fb}.gradient-badge{background:var(--accent-gradient);border:0;color:#fff;font-weight:850}.project-card-meta{display:flex;justify-content:space-between;gap:10px;color:#b8bfd1;font-size:.84rem;margin:16px 0}.project-actions{display:flex;gap:9px;flex-wrap:wrap}.planner-page{width:min(1480px,calc(100% - 22px))}.studio-top{align-items:center}.studio-layout{display:grid;grid-template-columns:minmax(300px,390px) 1fr;gap:22px;align-items:start}.studio-controls{position:sticky;top:88px;display:grid;gap:14px}.control-panel{padding:18px}.panel-heading{display:flex;gap:12px;align-items:flex-start;margin-bottom:14px}.panel-heading h3{margin:0 0 4px}.panel-heading p{margin:0;color:#b8bfd1;font-size:.88rem;line-height:1.45}.control-number{width:34px;height:34px;border-radius:50%;background:var(--accent-gradient);display:grid;place-items:center;color:#fff;font-weight:900;flex:none}.upload-zone{border:1px dashed rgba(255,255,255,.22);border-radius:22px;padding:20px;text-align:center;background:rgba(255,255,255,.055);display:block}.instagram-upload{border-color:rgba(225,48,108,.42);background:linear-gradient(135deg,rgba(254,218,117,.08),rgba(214,41,118,.09),rgba(79,91,213,.08))}.upload-zone input{display:none}.upload-zone strong{display:block;margin-bottom:6px}.upload-zone span{color:#b8bfd1;font-size:.9rem}.progress{height:8px;background:rgba(255,255,255,.1);border-radius:999px;overflow:hidden;margin-top:12px;display:none}.progress b{height:100%;display:block;width:0;background:var(--accent-gradient)}.member-list{margin-top:12px;display:grid;gap:6px;color:#b8bfd1;font-size:.88rem}.member-list div{display:flex;justify-content:space-between;gap:8px;padding:8px 0;border-top:1px solid rgba(255,255,255,.08)}.preview-workspace{min-width:0}.workspace-toolbar{display:flex;justify-content:space-between;gap:20px;margin-bottom:16px;align-items:flex-end}.workspace-toolbar h2{margin:8px 0 6px;font-size:clamp(1.8rem,3vw,3rem);letter-spacing:-.055em}.workspace-toolbar p{margin:0;color:#c1c7d8;line-height:1.55}.instagram-preview-shell{width:min(760px,100%);margin:0 auto;padding:14px;border-radius:44px;background:linear-gradient(145deg,rgba(255,255,255,.16),rgba(255,255,255,.05));box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.16)}.public-shell{width:min(640px,100%)}.instagram-preview{border-radius:34px;min-height:680px;box-shadow:inset 0 0 0 1px #eee;color:#111}.ig-statusbar{height:28px;display:flex;justify-content:space-between;align-items:center;padding:0 20px;font-size:.73rem;font-weight:800}.ig-appbar{height:50px;display:flex;align-items:center;justify-content:space-between;padding:0 14px;border-bottom:1px solid #efefef;background:#fff}.ig-appbar strong{font-size:1.05rem;letter-spacing:-.02em}.ig-back{border:0;background:transparent;font-size:2rem;line-height:1;color:#111;padding:0}.ig-app-icons{font-size:1.16rem;letter-spacing:5px}.ig-profile-header{display:grid;grid-template-columns:104px repeat(3,1fr);gap:8px;align-items:center;padding:18px 18px 8px}.avatar-lg{width:96px;height:96px;border-radius:50%;background:var(--accent-gradient);display:grid;place-items:center;overflow:hidden;font-weight:900;font-size:2rem;color:#fff}.instagram-avatar{padding:3px;background:var(--accent-gradient)}.instagram-avatar img,.avatar-lg img{width:100%;height:100%;object-fit:cover;border-radius:50%;background:#fff}.instagram-avatar span{width:100%;height:100%;border-radius:50%;display:grid;place-items:center;background:#111;color:#fff;border:3px solid #fff}.ig-count{text-align:center}.ig-count strong{display:block;font-size:1.06rem;letter-spacing:-.03em}.ig-count span{display:block;font-size:.79rem;color:#333}.ig-profile-copy{padding:2px 18px 12px;font-size:.9rem;line-height:1.4}.ig-profile-copy h2{font-size:.95rem;margin:0 0 2px}.ig-profile-copy p{margin:0 0 3px;color:#111}.ig-profile-copy .ig-handle-line{color:#666}.ig-profile-copy a{display:inline-block;color:#1b57c9;font-weight:700;margin-top:2px;word-break:break-all}.ig-profile-buttons{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;padding:0 18px 15px}.ig-profile-buttons button{border:0;background:#efefef;color:#111;border-radius:8px;padding:8px 6px;font-weight:850;font-size:.82rem}.ig-highlights{display:flex;gap:15px;overflow-x:auto;padding:0 18px 14px;scrollbar-width:none}.ig-highlights::-webkit-scrollbar{display:none}.ig-highlights div{display:grid;justify-items:center;gap:5px;min-width:60px}.highlight-ring{width:58px;height:58px;border-radius:50%;background:var(--accent-gradient);padding:3px;display:grid;place-items:center}.highlight-ring i{font-style:normal;width:100%;height:100%;border-radius:50%;background:#fff;display:grid;place-items:center;border:1px solid #eee}.ig-highlights b{font-size:.71rem;color:#222;font-weight:600;max-width:64px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ig-tabs{height:45px;border-top:1px solid #eee;border-bottom:1px solid #dedede;display:grid;grid-template-columns:repeat(3,1fr);background:#fff}.ig-tabs button{border:0;background:transparent;color:#8c8c8c;display:grid;place-items:center;font-size:1.15rem;position:relative}.ig-tabs button span{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}.ig-tabs button.active{color:#111}.ig-tabs button.active:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:#111}.instagram-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:#fff}.post-tile{position:relative;aspect-ratio:1/1;overflow:hidden;background:#f1f1f1;cursor:pointer;touch-action:manipulation;border:0;border-radius:0}.post-tile img,.post-tile video{width:100%;height:100%;object-fit:cover}.post-tile.dragging{opacity:.42}.post-tile.placeholder{cursor:default;background:linear-gradient(135deg,#f1f1f1,#fafafa)}.post-tile.placeholder:before{content:"";position:absolute;inset:26%;border-radius:12px;background:linear-gradient(135deg,#eee,#f7f7f7)}.post-overlay{position:absolute;inset:0;background:rgba(0,0,0,.48);display:flex;align-items:flex-end;padding:10px;color:#fff;font-size:.75rem;line-height:1.25;opacity:0;transition:.16s}.post-tile:hover .post-overlay{opacity:1}.post-actions{position:absolute;top:7px;left:7px;right:7px;display:flex;gap:6px;justify-content:space-between;opacity:0;transition:.16s;z-index:3}.post-tile:hover .post-actions,.post-tile:focus-within .post-actions{opacity:1}.icon-btn{border:0;border-radius:999px;background:rgba(0,0,0,.64);color:#fff;padding:6px 8px;cursor:pointer;font-size:.72rem}.video-badge{position:absolute;right:8px;top:8px;background:rgba(0,0,0,.55);border-radius:999px;padding:5px 8px;font-size:.72rem;color:#fff}.video-play{position:absolute;inset:0;display:grid;place-items:center;color:#fff;font-size:2rem;text-shadow:0 2px 18px rgba(0,0,0,.6);pointer-events:none}.ig-empty-note{padding:22px;text-align:center;color:#555;background:#fff;border-top:1px solid #eee}.ig-empty-note h2{font-size:1.1rem;margin:0 0 5px}.ig-empty-note p{margin:0;font-size:.9rem;color:#777}.share-preview-wrap{display:grid;place-items:center}.modal{position:fixed;inset:0;background:rgba(0,0,0,.72);display:none;align-items:center;justify-content:center;z-index:100;padding:16px}.modal.is-open{display:flex}.modal-card{width:min(680px,100%);max-height:92vh;overflow:auto;background:#111322;border:1px solid var(--line);border-radius:24px;padding:18px;box-shadow:var(--shadow)}.instagram-modal{background:#fff;color:#111}.instagram-modal .field label{color:#111}.instagram-modal .input{background:#f7f7f7;color:#111;border-color:#e2e2e2}.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.modal-head h3{margin:0}.close{border:0;background:transparent;color:inherit;font-size:1.5rem;cursor:pointer}.preview-media{border-radius:18px;overflow:hidden;background:#05070d;margin-bottom:14px}.preview-media img,.preview-media video{width:100%;max-height:62vh;object-fit:contain}.share-box{display:flex;gap:8px}.share-box input{min-width:0}.admin-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:16px}.admin-card{padding:18px}.admin-card strong{display:block;font-size:1.4rem}.admin-card span{color:#b8bfd1;font-size:.88rem}.panel{padding:18px}.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:18px}.table{width:100%;border-collapse:collapse;min-width:760px;background:rgba(255,255,255,.03)}.table th,.table td{padding:13px 14px;border-bottom:1px solid var(--line);text-align:left}.table th{color:#eef1fb;font-size:.84rem}.table td{color:#b8bfd1}.table td strong{color:#fff}.danger-zone{border-color:rgba(225,48,108,.3);background:rgba(225,48,108,.06)}.quota{height:10px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden}.quota span{display:block;height:100%;width:0;background:var(--accent-gradient)}.mobile-only{display:none}.sr-only{position:absolute;width:1px;height:1px;clip:rect(0,0,0,0);overflow:hidden;white-space:nowrap}.landing-schema{display:none}
@media(max-width:1120px){.hero-grid,.story-grid,.split-demo,.studio-layout{grid-template-columns:1fr}.hero-visual{min-height:auto}.card-upload{left:8px;top:16px}.card-share{right:8px;bottom:20px}.studio-controls{position:relative;top:0;grid-template-columns:repeat(2,1fr)}.preview-workspace{order:-1}.instagram-preview-shell{width:min(680px,100%)}}
@media(max-width:980px){.feature-grid,.dashboard-grid{grid-template-columns:repeat(2,1fr)}.admin-grid{grid-template-columns:repeat(2,1fr)}.trust-row{grid-template-columns:1fr}.hero{padding-top:54px}.mini-phone-stack{height:360px}.mini-phone.front{left:84px}.studio-controls{grid-template-columns:1fr}}
@media(max-width:720px){.site-header{padding:12px 16px}.nav-toggle{display:block}.site-nav{position:fixed;top:65px;left:12px;right:12px;display:none;flex-direction:column;align-items:stretch;gap:4px;padding:12px;border:1px solid var(--line);border-radius:20px;background:rgba(9,10,22,.96);box-shadow:var(--shadow)}.site-nav.is-open{display:flex}.site-nav a{padding:12px;border-radius:12px}.hero{padding:42px 0 36px}.hero-actions .btn,.project-actions .btn,.top-actions .btn{width:100%}.feature-grid,.dashboard-grid,.admin-grid{grid-template-columns:1fr}.clean-card{padding:20px}.instagram-cta,.site-footer,.top-row,.workspace-toolbar{flex-direction:column;align-items:flex-start}.auth-card{padding:22px}.app-shell{width:min(100% - 14px,1380px);margin-top:14px}.panel{padding:14px;border-radius:20px}.phone-shell{border-radius:38px;padding:9px}.instagram-mock,.instagram-preview{border-radius:30px}.ig-profile-line{grid-template-columns:74px repeat(3,1fr);padding-left:12px;padding-right:12px}.ig-avatar-ring{width:64px;height:64px}.ig-profile-header{grid-template-columns:82px repeat(3,1fr);padding:14px 12px 8px}.avatar-lg{width:74px;height:74px}.ig-profile-copy,.ig-profile-buttons,.ig-highlights{padding-left:12px;padding-right:12px}.ig-profile-buttons{grid-template-columns:1fr 1fr}.ig-profile-buttons button:nth-child(3){display:none}.ig-count strong{font-size:.95rem}.ig-count span{font-size:.7rem}.instagram-preview-shell{padding:7px;border-radius:34px}.instagram-grid{gap:1.5px}.post-actions{opacity:1;top:5px;left:5px;right:5px}.post-overlay{display:none}.icon-btn{padding:5px 7px;font-size:.65rem}.desktop-only{display:none}.mobile-only{display:inline-flex}.share-box{flex-direction:column}.grid-toolbar{align-items:flex-start;flex-direction:column}h1{letter-spacing:-.07em}.btn{min-height:42px}.floating-card{display:none}.mini-phone-stack{display:none}.split-demo{gap:10px}.table{min-width:680px}}
@media(max-width:420px){.container{width:min(100% - 22px,var(--max))}.ig-app-icons{letter-spacing:2px}.ig-highlights{gap:10px}.highlight-ring{width:52px;height:52px}.ig-highlights div{min-width:52px}.ig-profile-header{grid-template-columns:74px repeat(3,1fr);gap:4px}.avatar-lg{width:68px;height:68px}.ig-count span{font-size:.66rem}.ig-profile-copy{font-size:.84rem}.hero p.lead{font-size:1rem}.trust-row div{padding:13px}.workspace-toolbar h2{font-size:2rem}}

/* ===== Landing rework v3 ===== */
body.landing{
  background:
    radial-gradient(circle at 15% 10%, rgba(214,41,118,.18), transparent 26%),
    radial-gradient(circle at 82% 8%, rgba(79,91,213,.18), transparent 24%),
    radial-gradient(circle at 50% 55%, rgba(250,126,30,.08), transparent 34%),
    linear-gradient(180deg,#06070d 0%,#0a0d16 38%,#070810 100%);
}
body.landing .site-header{
  background:rgba(6,7,13,.72);
  border-bottom:1px solid rgba(255,255,255,.08);
}
body.landing .site-footer{
  border-top:1px solid rgba(255,255,255,.08);
  background:rgba(7,8,16,.92);
}
.landing-hero{
  position:relative;
  overflow:hidden;
  padding:88px 0 56px;
}
.landing-glow{
  position:absolute;
  border-radius:999px;
  filter:blur(60px);
  opacity:.55;
  animation:floatGlow 11s ease-in-out infinite;
  pointer-events:none;
}
.glow-a{width:340px;height:340px;left:-90px;top:30px;background:rgba(214,41,118,.28)}
.glow-b{width:320px;height:320px;right:-70px;top:80px;background:rgba(79,91,213,.25);animation-delay:-2s}
.glow-c{width:260px;height:260px;left:44%;bottom:30px;background:rgba(250,126,30,.16);animation-delay:-4s}
@keyframes floatGlow{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(0,-18px,0) scale(1.06)}}
.landing-hero-grid{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1.08fr);
  gap:38px;
  align-items:center;
}
.landing-copy h1{max-width:760px}
.landing-copy .lead{max-width:700px;color:#c7ccdd}
.landing-pill{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.14)}
.landing-trust div{
  background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.035));
  border-color:rgba(255,255,255,.09);
}
.landing-visual{position:relative;min-height:740px}
.hero-chip{max-width:220px}
.chip-left{left:0;top:94px}
.chip-right{right:18px;bottom:116px}
.product-stage{
  position:relative;
  display:grid;
  grid-template-columns:220px minmax(0,1fr);
  gap:16px;
  align-items:center;
  padding:18px;
  min-height:710px;
  border-radius:34px;
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.035));
  border:1px solid rgba(255,255,255,.1);
  box-shadow:0 25px 90px rgba(0,0,0,.22);
  backdrop-filter:blur(18px);
  overflow:hidden;
}
.product-stage:before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg,transparent 15%,rgba(255,255,255,.06) 40%,transparent 65%);
  transform:translateX(-100%);
  animation:heroSweep 8s ease-in-out infinite;
  pointer-events:none;
}
@keyframes heroSweep{0%,20%{transform:translateX(-100%)}45%,100%{transform:translateX(100%)}}
.stage-sidebar{display:grid;gap:10px;z-index:1}
.stage-card{
  display:grid;
  grid-template-columns:48px 1fr;
  gap:10px;
  padding:14px;
  border-radius:22px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.06);
  transition:.28s ease;
  opacity:.55;
}
.stage-card strong{display:block;font-size:.97rem}
.stage-card p{margin:4px 0 0;color:#a8afc7;font-size:.82rem;line-height:1.45}
.stage-card.active{opacity:1;transform:translateX(6px);background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.16);box-shadow:0 14px 36px rgba(0,0,0,.16)}
.step-no{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;font-weight:900;background:rgba(255,255,255,.08)}
.stage-card.active .step-no{background:var(--accent-gradient)}
.stage-device-wrap{position:relative;display:grid;place-items:center;min-height:650px}
.landing-phone{z-index:2;transform:perspective(1200px) rotateY(-7deg) rotateX(3deg);transition:transform .25s ease}
[data-tilt-zone]:hover .landing-phone{transform:perspective(1200px) rotateY(-4deg) rotateX(1deg) translateY(-2px)}
.landing-instagram{background:#fff;color:#111;min-height:640px}
.landing-stories i{background:#f4f4f4;padding:0;overflow:hidden}
.landing-stories i img{width:100%;height:100%;object-fit:cover;background:#fff}
.landing-grid-demo{gap:2px;background:#fff;position:relative}
.landing-grid-demo .demo-media{
  display:block;
  aspect-ratio:1/1;
  overflow:hidden;
  background:#f1f1f1;
  position:relative;
  opacity:0;
  transform:scale(.92);
  transition:transform .3s ease, opacity .3s ease;
}
.landing-grid-demo .demo-media img{width:100%;height:100%;object-fit:cover;display:block}
.landing-grid-demo .demo-media.is-visible{opacity:1;transform:scale(1)}
.landing-grid-demo .demo-media:after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.06));
}
.hud-widget{
  position:absolute;
  max-width:230px;
  padding:14px 16px;
  border-radius:22px;
  background:rgba(12,15,28,.86);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 18px 50px rgba(0,0,0,.26);
  backdrop-filter:blur(14px);
  opacity:.46;
  transform:scale(.94);
  transition:.28s ease;
  z-index:3;
}
.hud-widget.active{opacity:1;transform:scale(1)}
.widget-label{display:inline-flex;padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.07);font-size:.72rem;font-weight:800;color:#e8ebf8;margin-bottom:10px}
.hud-widget strong{display:block;font-size:1rem}
.hud-widget p{margin:6px 0 0;color:#b6bdd4;line-height:1.45;font-size:.84rem}
.widget-upload{right:10px;top:28px}
.widget-stack{left:10px;top:220px}
.widget-reorder{right:0;bottom:176px}
.widget-share{left:22px;bottom:42px}
.widget-stack ul{padding:0;margin:6px 0 0;list-style:none;display:grid;gap:8px}
.widget-stack li{display:grid;grid-template-columns:10px 1fr auto;gap:8px;align-items:center;color:#dde2f3;font-size:.8rem}
.widget-stack li span{width:8px;height:8px;border-radius:50%;background:#33d17a;box-shadow:0 0 0 5px rgba(51,209,122,.12)}
.widget-stack li b{font-size:.72rem;color:#8ce3b4}
.widget-reorder .mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:4px}
.widget-reorder .mini-grid span{display:block;aspect-ratio:1/1;border-radius:9px;background:linear-gradient(135deg,#2b2f48,#191d31);border:1px solid rgba(255,255,255,.08)}
.landing-section,.landing-workflow,.landing-gallery-section,.landing-cta-wrap{position:relative}
.landing-section{padding-top:76px}
.landing-title{margin-bottom:28px}
.landing-title p{color:#bcc3d9}
.landing-feature-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.landing-feature-card{
  padding:24px;
  background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.028));
  border:1px solid rgba(255,255,255,.09);
}
.landing-feature-card p{color:#b7bfd6}
.landing-workflow{padding-top:34px}
.workflow-grid-landing{display:grid;grid-template-columns:.86fr 1.14fr;gap:32px;align-items:start}
.workflow-simulator{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  align-items:stretch;
}
.workflow-steps-landing{display:grid;gap:14px}
.workflow-step-card{
  display:grid;
  grid-template-columns:46px 1fr;
  gap:12px;
  padding:16px;
  border-radius:24px;
  background:rgba(255,255,255,.045);
  border:1px solid rgba(255,255,255,.08);
  opacity:.6;
  transform:translateY(0);
  transition:.25s ease;
}
.workflow-step-card span{width:42px;height:42px;border-radius:14px;background:rgba(255,255,255,.08);display:grid;place-items:center;font-weight:900}
.workflow-step-card h3{margin:0 0 6px;font-size:1rem}
.workflow-step-card p{margin:0;color:#b5bdd3;line-height:1.5;font-size:.88rem}
.workflow-step-card.active{opacity:1;transform:translateY(-2px);background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.16);box-shadow:0 16px 40px rgba(0,0,0,.16)}
.workflow-step-card.active span{background:var(--accent-gradient)}
.workflow-visual-board{
  min-height:360px;
  padding:18px;
  border-radius:28px;
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.035));
  border:1px solid rgba(255,255,255,.1);
  position:relative;
  overflow:hidden;
}
.workflow-progress{height:8px;border-radius:999px;background:rgba(255,255,255,.06);overflow:hidden;margin-bottom:18px}
.workflow-progress span{display:block;height:100%;width:25%;background:var(--accent-gradient);transition:width .32s ease}
.workflow-stage{display:none;animation:fadeUp .3s ease}
.workflow-stage.is-active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.visual-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.visual-header span{font-size:.84rem;color:#b8bfd4}
.visual-project-card{display:grid;grid-template-columns:68px 1fr;gap:14px;align-items:center;padding:16px;border-radius:24px;background:rgba(255,255,255,.055)}
.visual-avatar{width:68px;height:68px;border-radius:50%;background:var(--accent-gradient);position:relative}
.visual-avatar:after{content:"";position:absolute;inset:4px;border-radius:50%;background:url('../img/demo/fashion-editorial.svg') center/cover no-repeat #fff}
.visual-project-card p{margin:4px 0 0;color:#b5bdd3}
.upload-list-demo{display:grid;gap:10px}
.upload-list-demo div,.share-preview-demo{padding:14px;border-radius:18px;background:rgba(255,255,255,.055)}
.upload-list-demo div{display:grid;grid-template-columns:10px 1fr auto;align-items:center;gap:10px;color:#eef1fb}
.upload-list-demo i{width:8px;height:8px;border-radius:50%;background:#38d39f;box-shadow:0 0 0 5px rgba(56,211,159,.12)}
.upload-list-demo b{font-size:.78rem;color:#8ce2b4}
.sim-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.sim-grid span{display:block;aspect-ratio:1/1;border-radius:14px;overflow:hidden;background:#1b2035}
.sim-grid img{width:100%;height:100%;object-fit:cover}
.share-preview-demo p{margin:.4rem 0 .9rem;color:#b5bdd3}
.share-link-demo{padding:10px 12px;border-radius:14px;background:#0d1121;color:#dfe6fb;font-size:.85rem;overflow:auto}
.landing-gallery-section{padding-top:48px}
.landing-title.narrow{max-width:760px}
.landing-gallery-marquee{
  overflow:hidden;
  border-radius:28px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
  padding:18px 0;
}
.gallery-track{
  display:flex;
  gap:16px;
  width:max-content;
  animation:marqueeSlide 42s linear infinite;
}
.gallery-card{
  width:190px;
  height:190px;
  margin:0;
  border-radius:26px;
  overflow:hidden;
  background:#121728;
  border:1px solid rgba(255,255,255,.06);
  box-shadow:0 12px 34px rgba(0,0,0,.18);
}
.gallery-card img{width:100%;height:100%;object-fit:cover}
@keyframes marqueeSlide{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.landing-cta{
  gap:18px;
  border-radius:30px;
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.1);
}
.landing-cta h2{margin:10px 0 12px;font-size:clamp(2rem,4vw,3.6rem);line-height:.96;letter-spacing:-.06em}
.landing-cta p{margin:0;color:#c6cce0;max-width:660px}
.landing-cta-actions{display:flex;flex-wrap:wrap;gap:12px}
@media (max-width:1200px){
  .landing-hero-grid,.workflow-grid-landing,.workflow-simulator{grid-template-columns:1fr}
  .landing-visual{min-height:auto}
  .product-stage{grid-template-columns:1fr;min-height:auto}
  .stage-sidebar{grid-template-columns:repeat(2,minmax(0,1fr))}
  .stage-card.active{transform:none}
  .hero-chip{display:none}
  .stage-device-wrap{min-height:700px}
}
@media (max-width:980px){
  .landing-feature-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .stage-sidebar{grid-template-columns:1fr 1fr}
}
@media (max-width:720px){
  .landing-hero{padding-top:44px}
  .landing-hero-grid{gap:24px}
  .landing-visual{min-height:auto}
  .product-stage{padding:14px;border-radius:26px}
  .stage-sidebar{grid-template-columns:1fr}
  .stage-device-wrap{min-height:auto;padding:8px 0 190px}
  .landing-phone{transform:none;width:min(100%,390px)}
  .hud-widget{max-width:none;width:calc(100% - 16px);left:8px;right:8px}
  .widget-upload{top:auto;bottom:122px}
  .widget-stack{top:auto;bottom:80px}
  .widget-reorder{bottom:36px}
  .widget-share{bottom:-8px}
  .landing-feature-grid{grid-template-columns:1fr}
  .gallery-card{width:150px;height:150px}
  .landing-cta-actions .btn{width:100%}
}

/* =========================================================
   GramGrid premium landing v4
   ========================================================= */
body.gramgrid-home{
  background:#05060b;
  color:#fff;
}
body.gramgrid-home:before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-2;
  background:
    radial-gradient(circle at 12% 12%,rgba(225,48,108,.22),transparent 30%),
    radial-gradient(circle at 82% 8%,rgba(79,91,213,.18),transparent 26%),
    radial-gradient(circle at 50% 68%,rgba(250,176,69,.08),transparent 34%),
    linear-gradient(180deg,#05060b 0%,#0a0d17 52%,#05060b 100%);
}
body.gramgrid-home:after{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-1;
  opacity:.16;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(circle at 50% 18%,#000,transparent 70%);
}
.gramgrid-home .site-header{
  background:rgba(5,6,11,.66);
  border-bottom:1px solid rgba(255,255,255,.08);
  backdrop-filter:blur(22px);
}
.gramgrid-home .brand-mark{
  border-radius:15px;
  background:linear-gradient(135deg,#feda75 0%,#fa7e1e 24%,#d62976 52%,#962fbf 76%,#4f5bd5 100%);
  box-shadow:0 18px 44px rgba(214,41,118,.22), inset 0 0 0 1px rgba(255,255,255,.3);
}
.gramgrid-home .site-footer{
  background:#05060b;
  border-top:1px solid rgba(255,255,255,.08);
}
.gg-hero{
  position:relative;
  overflow:hidden;
  min-height:calc(100vh - 70px);
  padding:70px 0 50px;
}
.gg-noise{
  position:absolute;
  inset:0;
  opacity:.13;
  pointer-events:none;
  background:
    radial-gradient(circle at 20% 30%,rgba(255,255,255,.12) 0 1px,transparent 1.5px),
    radial-gradient(circle at 70% 60%,rgba(255,255,255,.10) 0 1px,transparent 1.5px);
  background-size:22px 22px,31px 31px;
  mix-blend-mode:screen;
}
.gg-orb{
  position:absolute;
  border-radius:999px;
  filter:blur(64px);
  opacity:.58;
  pointer-events:none;
  animation:ggOrb 12s ease-in-out infinite;
}
.gg-orb-a{width:370px;height:370px;left:-130px;top:70px;background:#d62976}
.gg-orb-b{width:340px;height:340px;right:-80px;top:40px;background:#4f5bd5;animation-delay:-4s}
.gg-orb-c{width:280px;height:280px;left:44%;bottom:70px;background:#fa7e1e;opacity:.28;animation-delay:-7s}
@keyframes ggOrb{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(20px,-26px,0) scale(1.07)}}
.gg-hero-inner{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0,.88fr) minmax(0,1.12fr);
  gap:42px;
  align-items:center;
}
.gg-kicker{
  display:inline-flex;
  align-items:center;
  gap:9px;
  padding:9px 13px;
  border-radius:999px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);
  color:#e9ecff;
  font-weight:850;
  font-size:.86rem;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
.gg-kicker i{
  width:10px;
  height:10px;
  border-radius:50%;
  background:linear-gradient(135deg,#feda75,#d62976,#4f5bd5);
  box-shadow:0 0 22px rgba(214,41,118,.85);
}
.gg-hero-copy h1{
  font-size:clamp(3.1rem,6.5vw,6.6rem);
  line-height:.88;
  letter-spacing:-.085em;
  margin:19px 0 20px;
  max-width:830px;
}
.gg-lead{
  margin:0;
  max-width:720px;
  color:#c2c8d9;
  font-size:clamp(1.05rem,1.7vw,1.24rem);
  line-height:1.68;
}
.gg-hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:30px;
}
.gg-primary{
  min-height:50px;
  padding:13px 22px;
  box-shadow:0 18px 50px rgba(214,41,118,.28),0 0 0 1px rgba(255,255,255,.18) inset;
}
.gg-secondary{
  min-height:50px;
  padding:13px 22px;
  background:rgba(255,255,255,.07);
  border-color:rgba(255,255,255,.14);
}
.gg-proof{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin-top:32px;
}
.gg-proof div{
  padding:16px;
  border-radius:22px;
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.035));
  border:1px solid rgba(255,255,255,.09);
}
.gg-proof strong{
  display:block;
  font-size:1.08rem;
  letter-spacing:-.03em;
}
.gg-proof span{
  display:block;
  margin-top:4px;
  color:#98a1b9;
  font-size:.86rem;
}
.gg-demo{
  position:relative;
}
.gg-demo-shell{
  position:relative;
  transform:perspective(1400px) rotateY(-4deg) rotateX(2deg);
  transform-origin:center;
  transition:.35s ease;
}
.gg-demo:hover .gg-demo-shell{
  transform:perspective(1400px) rotateY(-1deg) rotateX(1deg) translateY(-4px);
}
.gg-window{
  position:relative;
  min-height:720px;
  border-radius:34px;
  background:linear-gradient(180deg,rgba(255,255,255,.105),rgba(255,255,255,.045));
  border:1px solid rgba(255,255,255,.13);
  box-shadow:0 40px 120px rgba(0,0,0,.36), inset 0 1px 0 rgba(255,255,255,.12);
  overflow:hidden;
  backdrop-filter:blur(24px);
}
.gg-window:before{
  content:"";
  position:absolute;
  inset:-1px;
  background:linear-gradient(120deg,transparent 20%,rgba(255,255,255,.12),transparent 48%);
  transform:translateX(-110%);
  animation:ggShine 7.4s ease-in-out infinite;
  pointer-events:none;
}
@keyframes ggShine{0%,24%{transform:translateX(-110%)}54%,100%{transform:translateX(110%)}}
.gg-window-top{
  height:54px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:0 18px;
  border-bottom:1px solid rgba(255,255,255,.09);
  background:rgba(5,6,11,.32);
}
.gg-window-top strong{font-size:.95rem;color:#eef2ff}
.gg-window-top em{font-style:normal;color:#8f99b6;font-size:.82rem}
.gg-dots{display:flex;gap:7px}
.gg-dots span{width:10px;height:10px;border-radius:50%;background:#ff5f57}
.gg-dots span:nth-child(2){background:#febc2e}
.gg-dots span:nth-child(3){background:#28c840}
.gg-studio{
  display:grid;
  grid-template-columns:168px 230px minmax(0,1fr);
  gap:14px;
  padding:14px;
}
.gg-studio-side,
.gg-media-panel,
.gg-preview-panel{
  min-height:636px;
  border-radius:26px;
  background:rgba(8,10,20,.72);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
}
.gg-studio-side{
  padding:16px;
  display:flex;
  flex-direction:column;
}
.gg-side-logo{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:18px;
  font-weight:950;
  letter-spacing:-.04em;
}
.gg-side-logo span{
  width:32px;
  height:32px;
  border-radius:12px;
  background:linear-gradient(135deg,#feda75,#fa7e1e,#d62976,#962fbf,#4f5bd5);
}
.gg-studio-side nav{display:grid;gap:7px}
.gg-studio-side nav a{
  padding:11px 12px;
  border-radius:15px;
  color:#9da7c0;
  font-weight:800;
  font-size:.86rem;
}
.gg-studio-side nav a.active{
  background:rgba(255,255,255,.09);
  color:#fff;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.07);
}
.gg-client-card{
  margin-top:auto;
  padding:14px;
  border-radius:18px;
  background:linear-gradient(135deg,rgba(214,41,118,.18),rgba(79,91,213,.12));
  border:1px solid rgba(255,255,255,.09);
}
.gg-client-card small{color:#aab4cc}
.gg-client-card strong{display:block;margin-top:4px}
.gg-client-card p{margin:4px 0 0;color:#aab4cc;font-size:.82rem}
.gg-media-panel{padding:14px}
.gg-panel-head,.gg-preview-toolbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.gg-panel-head b,.gg-preview-toolbar strong{display:block}
.gg-panel-head span,.gg-preview-toolbar span{display:block;color:#8d98b4;font-size:.78rem;margin-top:2px}
.gg-upload-drop{
  margin-top:14px;
  height:150px;
  border:1px dashed rgba(255,255,255,.18);
  border-radius:22px;
  display:grid;
  place-items:center;
  align-content:center;
  text-align:center;
  background:radial-gradient(circle at 50% 0%,rgba(214,41,118,.18),transparent 60%),rgba(255,255,255,.035);
}
.gg-upload-drop i{
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  border-radius:15px;
  font-style:normal;
  font-size:1.4rem;
  background:var(--accent-gradient);
  margin-bottom:10px;
}
.gg-upload-drop strong{font-size:.95rem}
.gg-upload-drop span{font-size:.78rem;color:#9aa4bd;margin-top:3px}
.gg-upload-list{
  display:grid;
  gap:10px;
  margin-top:14px;
}
.gg-upload-item{
  display:grid;
  grid-template-columns:48px 1fr auto;
  gap:10px;
  align-items:center;
  padding:9px;
  border-radius:18px;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(255,255,255,.065);
  opacity:0;
  transform:translateY(12px);
  animation:ggUploadIn 6s ease-in-out infinite;
  animation-delay:calc(var(--d) * .45s);
}
@keyframes ggUploadIn{
  0%,9%{opacity:0;transform:translateY(12px)}
  18%,80%{opacity:1;transform:translateY(0)}
  100%{opacity:0;transform:translateY(-4px)}
}
.gg-upload-item img{
  width:48px;
  height:48px;
  border-radius:14px;
  object-fit:cover;
}
.gg-upload-item strong{display:block;font-size:.78rem;color:#eef2ff}
.gg-upload-item span{display:block;font-size:.72rem;color:#8de5b5;margin-top:2px}
.gg-upload-item b{
  padding:5px 8px;
  border-radius:999px;
  background:rgba(56,211,159,.12);
  color:#8de5b5;
  font-size:.68rem;
}
.gg-preview-panel{
  position:relative;
  padding:14px;
  display:grid;
  justify-items:center;
  overflow:hidden;
}
.gg-preview-toolbar{
  width:100%;
  align-self:start;
}
.gg-preview-toolbar button{
  border:0;
  border-radius:999px;
  color:#fff;
  padding:9px 12px;
  font-weight:850;
  background:var(--accent-gradient);
}
.gg-phone{
  position:relative;
  width:320px;
  border-radius:42px;
  background:#0a0b0e;
  padding:10px;
  margin-top:12px;
  box-shadow:0 24px 70px rgba(0,0,0,.42),0 0 0 1px rgba(255,255,255,.14);
}
.gg-speaker{
  position:absolute;
  width:88px;
  height:6px;
  top:8px;
  left:50%;
  transform:translateX(-50%);
  border-radius:999px;
  background:#24252b;
  z-index:2;
}
.gg-ig{
  overflow:hidden;
  border-radius:34px;
  background:#fff;
  color:#101010;
}
.gg-ig-bar{
  height:42px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 14px;
  border-bottom:1px solid #eee;
}
.gg-ig-bar strong{font-size:.94rem}
.gg-ig-bar em{font-style:normal;letter-spacing:4px}
.gg-ig-profile{
  display:grid;
  grid-template-columns:75px repeat(3,1fr);
  gap:7px;
  padding:13px 13px 6px;
  align-items:center;
  text-align:center;
}
.gg-avatar{
  width:66px;
  height:66px;
  border-radius:50%;
  padding:3px;
  background:var(--accent-gradient);
}
.gg-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;border:3px solid #fff}
.gg-ig-profile b{display:block;font-size:.91rem}
.gg-ig-profile span{display:block;font-size:.66rem;color:#333}
.gg-bio{
  padding:0 14px 9px;
  display:grid;
  gap:2px;
  font-size:.75rem;
  line-height:1.35;
}
.gg-bio a{color:#1b57c9;font-weight:800}
.gg-buttons{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:6px;
  padding:0 14px 11px;
}
.gg-buttons span{
  padding:7px 6px;
  border-radius:8px;
  background:#efefef;
  text-align:center;
  font-weight:850;
  font-size:.74rem;
}
.gg-highlights{
  display:flex;
  gap:12px;
  padding:0 14px 10px;
  overflow:hidden;
}
.gg-highlights span{
  min-width:48px;
  display:grid;
  justify-items:center;
  gap:4px;
  font-size:.62rem;
}
.gg-highlights i{
  width:46px;
  height:46px;
  border-radius:50%;
  padding:2px;
  display:block;
  background:var(--accent-gradient);
}
.gg-highlights img{width:100%;height:100%;object-fit:cover;border-radius:50%;background:#fff}
.gg-tabs{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  height:34px;
  border-top:1px solid #eee;
  border-bottom:1px solid #dedede;
  align-items:center;
  text-align:center;
}
.gg-tabs b:first-child{height:34px;display:grid;place-items:center;border-bottom:2px solid #111}
.gg-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2px;
  background:#fff;
}
.gg-grid span{
  display:block;
  aspect-ratio:1/1;
  overflow:hidden;
  background:#eee;
  opacity:0;
  transform:scale(.82);
  animation:ggGridPop 6s ease-in-out infinite;
  animation-delay:calc(var(--i) * .13s + 1.1s);
}
.gg-grid span img{width:100%;height:100%;object-fit:cover}
@keyframes ggGridPop{
  0%,15%{opacity:0;transform:scale(.82)}
  24%,83%{opacity:1;transform:scale(1)}
  100%{opacity:.7;transform:scale(.96)}
}
.gg-drag-card{
  position:absolute;
  width:112px;
  padding:8px;
  border-radius:18px;
  background:rgba(255,255,255,.9);
  color:#111;
  box-shadow:0 22px 55px rgba(0,0,0,.28);
  z-index:8;
}
.gg-drag-card img{width:100%;aspect-ratio:1/1;border-radius:13px;object-fit:cover}
.gg-drag-card span{display:block;margin-top:6px;font-size:.73rem;font-weight:900;text-align:center}
.gg-drag-1{
  left:345px;
  top:235px;
  animation:ggDragOne 6s ease-in-out infinite;
}
.gg-drag-2{
  left:410px;
  top:380px;
  animation:ggDragTwo 6s ease-in-out infinite;
  animation-delay:.5s;
}
@keyframes ggDragOne{
  0%,15%{opacity:0;transform:translate(0,0) scale(.9)}
  25%{opacity:1;transform:translate(0,0) scale(1)}
  48%,70%{opacity:1;transform:translate(335px,124px) scale(.82)}
  82%,100%{opacity:0;transform:translate(335px,124px) scale(.72)}
}
@keyframes ggDragTwo{
  0%,22%{opacity:0;transform:translate(0,0) scale(.9)}
  32%{opacity:1;transform:translate(0,0) scale(1)}
  55%,74%{opacity:1;transform:translate(280px,34px) scale(.82)}
  86%,100%{opacity:0;transform:translate(280px,34px) scale(.72)}
}
.gg-cursor{
  position:absolute;
  width:26px;
  height:26px;
  z-index:10;
  left:438px;
  top:330px;
  filter:drop-shadow(0 8px 14px rgba(0,0,0,.3));
  animation:ggCursor 6s ease-in-out infinite;
}
.gg-cursor:before{
  content:"";
  position:absolute;
  width:0;height:0;
  border-left:18px solid #fff;
  border-top:12px solid transparent;
  border-bottom:12px solid transparent;
  transform:rotate(45deg);
}
@keyframes ggCursor{
  0%,16%{opacity:0;transform:translate(0,0)}
  24%{opacity:1;transform:translate(0,0)}
  52%,75%{opacity:1;transform:translate(320px,100px)}
  88%,100%{opacity:0;transform:translate(320px,100px)}
}
.gg-share-toast{
  position:absolute;
  right:24px;
  bottom:28px;
  z-index:12;
  display:grid;
  grid-template-columns:38px 1fr;
  gap:10px;
  align-items:center;
  width:250px;
  padding:12px;
  border-radius:20px;
  background:rgba(15,18,33,.92);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 22px 55px rgba(0,0,0,.28);
  opacity:0;
  transform:translateY(16px);
  animation:ggToast 6s ease-in-out infinite;
}
.gg-share-toast i{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;background:#36d399;color:#06130d;font-style:normal;font-weight:950}
.gg-share-toast strong{display:block;font-size:.9rem}
.gg-share-toast span{display:block;color:#aab4cc;font-size:.78rem;margin-top:2px}
@keyframes ggToast{
  0%,66%{opacity:0;transform:translateY(16px)}
  74%,92%{opacity:1;transform:translateY(0)}
  100%{opacity:0;transform:translateY(8px)}
}
.gg-section{
  position:relative;
  padding:84px 0;
}
.gg-section-head{
  max-width:850px;
  margin:0 auto 34px;
  text-align:center;
}
.gg-section-head.left{text-align:left;margin-left:0}
.gg-section-head h2{
  font-size:clamp(2.25rem,4.6vw,4.5rem);
  line-height:.94;
  letter-spacing:-.075em;
  margin:16px 0 12px;
}
.gg-section-head p{
  margin:0;
  color:#b8bfd3;
  font-size:1.05rem;
  line-height:1.7;
}
.gg-workflow{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
}
.gg-flow-card{
  position:relative;
  min-height:230px;
  padding:24px;
  border-radius:28px;
  background:linear-gradient(180deg,rgba(255,255,255,.065),rgba(255,255,255,.028));
  border:1px solid rgba(255,255,255,.09);
  overflow:hidden;
  opacity:.78;
  transition:.3s ease;
}
.gg-flow-card:after{
  content:"";
  position:absolute;
  inset:auto -20% -40% -20%;
  height:120px;
  background:radial-gradient(ellipse at center,rgba(214,41,118,.26),transparent 70%);
  opacity:0;
  transition:.3s ease;
}
.gg-flow-card.active{
  opacity:1;
  transform:translateY(-5px);
  border-color:rgba(255,255,255,.2);
  box-shadow:0 24px 70px rgba(0,0,0,.24);
}
.gg-flow-card.active:after{opacity:1}
.gg-flow-card span{
  display:inline-grid;
  place-items:center;
  width:48px;
  height:48px;
  border-radius:16px;
  background:var(--accent-gradient);
  font-weight:950;
}
.gg-flow-card h3{
  margin:22px 0 10px;
  font-size:1.22rem;
  letter-spacing:-.03em;
}
.gg-flow-card p{
  margin:0;
  color:#b3bbd1;
  line-height:1.6;
}
.gg-showcase{
  background:
    radial-gradient(circle at 80% 50%,rgba(79,91,213,.14),transparent 34%),
    linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,.01));
}
.gg-showcase-grid{
  display:grid;
  grid-template-columns:.88fr 1.12fr;
  gap:34px;
  align-items:start;
}
.gg-feature-stack{
  display:grid;
  gap:14px;
}
.gg-feature{
  display:grid;
  grid-template-columns:62px 1fr;
  gap:16px;
  padding:20px;
  border-radius:26px;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(255,255,255,.09);
}
.gg-feature b{
  width:52px;height:52px;border-radius:18px;display:grid;place-items:center;background:rgba(255,255,255,.08);color:#fff;
}
.gg-feature h3{margin:0 0 7px;font-size:1.15rem}
.gg-feature p{margin:0;color:#b5bdd3;line-height:1.58}
.gg-gallery{padding-top:64px}
.gg-marquee{
  overflow:hidden;
  padding:18px 0;
  border-radius:32px;
  background:rgba(255,255,255,.035);
  border:1px solid rgba(255,255,255,.08);
}
.gg-marquee-track{
  width:max-content;
  display:flex;
  gap:16px;
  animation:ggMarquee 36s linear infinite;
}
.gg-marquee figure{
  margin:0;
  width:185px;
  height:185px;
  border-radius:28px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.08);
  background:#111827;
  box-shadow:0 18px 44px rgba(0,0,0,.22);
}
.gg-marquee img{width:100%;height:100%;object-fit:cover}
@keyframes ggMarquee{to{transform:translateX(-50%)}}
.gg-final{
  padding-top:42px;
}
.gg-final-card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:40px;
  border-radius:36px;
  background:
    radial-gradient(circle at 20% 20%,rgba(214,41,118,.25),transparent 35%),
    radial-gradient(circle at 85% 10%,rgba(79,91,213,.22),transparent 34%),
    linear-gradient(180deg,rgba(255,255,255,.09),rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 30px 100px rgba(0,0,0,.28);
}
.gg-final-card h2{
  max-width:820px;
  font-size:clamp(2.3rem,4.4vw,4.8rem);
  letter-spacing:-.075em;
  line-height:.94;
  margin:16px 0 12px;
}
.gg-final-card p{
  max-width:720px;
  color:#c1c8d9;
  margin:0;
  line-height:1.65;
}
@media(max-width:1240px){
  .gg-hero-inner,.gg-showcase-grid{grid-template-columns:1fr}
  .gg-demo-shell{transform:none}
  .gg-window{min-height:auto}
  .gg-studio{grid-template-columns:150px 220px 1fr}
  .gg-workflow{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:980px){
  .gg-studio{grid-template-columns:1fr}
  .gg-studio-side,.gg-media-panel,.gg-preview-panel{min-height:auto}
  .gg-studio-side nav{grid-template-columns:repeat(4,1fr)}
  .gg-client-card{margin-top:14px}
  .gg-upload-list{grid-template-columns:repeat(3,1fr)}
  .gg-upload-item{grid-template-columns:1fr;align-items:start}
  .gg-upload-item b{justify-self:start}
  .gg-drag-card,.gg-cursor{display:none}
}
@media(max-width:720px){
  .gg-hero{padding-top:44px}
  .gg-hero-copy h1{font-size:clamp(2.85rem,16vw,4.2rem)}
  .gg-hero-actions .btn{width:100%}
  .gg-proof{grid-template-columns:1fr}
  .gg-window{border-radius:26px}
  .gg-window-top em{display:none}
  .gg-studio{padding:10px}
  .gg-studio-side nav{grid-template-columns:1fr 1fr}
  .gg-upload-list{grid-template-columns:1fr}
  .gg-phone{width:min(100%,320px)}
  .gg-share-toast{left:12px;right:12px;bottom:12px;width:auto}
  .gg-workflow{grid-template-columns:1fr}
  .gg-flow-card{min-height:auto}
  .gg-feature{grid-template-columns:1fr}
  .gg-marquee figure{width:145px;height:145px;border-radius:22px}
  .gg-final-card{flex-direction:column;align-items:flex-start;padding:26px}
  .gg-final-card .btn{width:100%}
}
@media(max-width:420px){
  .gg-ig-profile{grid-template-columns:64px repeat(3,1fr);padding-left:9px;padding-right:9px}
  .gg-avatar{width:58px;height:58px}
  .gg-ig-profile b{font-size:.82rem}
  .gg-ig-profile span{font-size:.58rem}
  .gg-bio,.gg-buttons,.gg-highlights{padding-left:10px;padding-right:10px}
}

/* ===== GramGrid app planner v7 ===== */
html,body{max-width:100%;overflow-x:hidden}.app-page{background:radial-gradient(circle at 12% 0%,rgba(225,48,108,.14),transparent 32%),radial-gradient(circle at 85% 6%,rgba(64,93,230,.16),transparent 34%),#070912}.gram-studio-v2{width:min(1520px,calc(100% - 28px));margin:22px auto 56px}.studio-hero-row{display:flex;align-items:flex-start;justify-content:space-between;gap:22px;margin-bottom:18px}.studio-title{max-width:780px}.studio-title h1{font-size:clamp(2.1rem,4vw,4.3rem);line-height:.92;letter-spacing:-.07em;margin:12px 0 10px}.studio-title p{color:#c2c8db;line-height:1.65;max-width:760px}.studio-actions{margin-top:26px}.studio-toolbar-v2{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:12px;border:1px solid rgba(255,255,255,.1);border-radius:22px;background:rgba(255,255,255,.045);backdrop-filter:blur(16px);margin-bottom:16px}.toolbar-group{display:inline-flex;align-items:center;gap:8px;padding:6px 8px;border-radius:999px;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.08)}.toolbar-group span{font-size:.8rem;color:#aeb6ca;font-weight:800}.tool-btn{border:0;border-radius:999px;min-width:38px;height:34px;padding:0 12px;background:rgba(255,255,255,.08);color:#fff;font-weight:900}.tool-btn:hover{background:rgba(255,255,255,.14)}.tool-btn[disabled]{opacity:.55;cursor:not-allowed}.studio-grid-v2{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:18px;align-items:start}.phone-workspace-card,.project-tools-card .panel{border:1px solid rgba(255,255,255,.1);background:linear-gradient(180deg,rgba(255,255,255,.065),rgba(255,255,255,.03));box-shadow:0 24px 75px rgba(0,0,0,.24);border-radius:28px}.phone-workspace-card{min-width:0;padding:18px;overflow:hidden}.workspace-head-v2{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px}.workspace-head-v2 h2{font-size:clamp(1.65rem,2.4vw,2.8rem);line-height:1;letter-spacing:-.055em;margin:10px 0 7px}.workspace-head-v2 p{color:#aeb7cc;margin:0;line-height:1.55}.post-stat-pill{min-width:72px;height:72px;border-radius:22px;background:var(--accent-gradient);display:grid;place-items:center;box-shadow:0 16px 40px rgba(225,48,108,.28)}.post-stat-pill strong{font-size:1.4rem;line-height:1}.post-stat-pill span{font-size:.72rem;margin-top:-14px;font-weight:800}.phone-scale-stage{--phone-scale:.84;display:grid;place-items:start center;transform:translateZ(0);transition:height .18s ease;overflow:visible}.phone-scale-stage .app-phone-shell{transform:scale(var(--phone-scale));transform-origin:top center}.app-phone-shell{width:430px;max-width:100%;border-radius:48px;padding:11px;background:#151824;box-shadow:0 28px 90px rgba(0,0,0,.36),0 0 0 1px rgba(255,255,255,.12)}.editable-phone{min-height:auto;border-radius:38px;background:#fff;color:#111;transition:background .18s ease,color .18s ease}.editable-phone .ig-statusbar{height:30px;padding:0 16px;display:flex;align-items:center;justify-content:space-between;font-size:.72rem;font-weight:800;background:inherit;border-bottom:0}.editable-phone .ig-appbar{height:48px}.editable-phone .ig-app-icons{display:flex;align-items:center;gap:8px;letter-spacing:0}.editable-phone .ig-app-icons button{border:0;background:transparent;color:inherit;font-size:1.22rem;font-weight:900;line-height:1;padding:4px;cursor:pointer}.editable-phone .ig-profile-header{grid-template-columns:104px repeat(3,1fr);padding:15px 18px 8px}.editable-phone .avatar-lg{width:94px;height:94px;border:0;cursor:pointer;position:relative}.avatar-edit-target em,.profile-avatar-row .instagram-avatar em{position:absolute;left:50%;bottom:1px;transform:translateX(-50%);font-style:normal;font-size:.66rem;background:rgba(0,0,0,.68);color:#fff;padding:3px 7px;border-radius:999px;opacity:0;transition:.15s}.avatar-edit-target:hover em,.profile-avatar-row .instagram-avatar:hover em{opacity:1}.editable-profile-copy{width:100%;border:0;background:transparent;color:inherit;text-align:left;cursor:pointer;position:relative}.editable-profile-copy:hover{background:rgba(0,0,0,.025)}.editable-profile-copy small{display:inline-flex;margin-top:6px;font-size:.72rem;font-weight:800;color:#405de6}.readonly-copy{display:block;border:0;background:transparent;color:inherit;text-align:left}.editable-phone .ig-profile-buttons button{cursor:pointer}.highlight-editor{padding-top:2px;padding-bottom:15px;gap:16px}.highlight-editor .highlight-item{border:0;background:transparent;color:inherit;display:grid;justify-items:center;gap:6px;min-width:74px;cursor:pointer;padding:0}.highlight-editor .highlight-ring{width:70px;height:70px;border-radius:50%;padding:3px;background:var(--accent-gradient);display:grid;place-items:center}.highlight-editor .highlight-ring img,.highlight-preview-big img{width:100%;height:100%;object-fit:cover;border-radius:50%;background:#fff;border:3px solid #fff}.highlight-editor .highlight-ring i{width:100%;height:100%;border-radius:50%;background:#fff;display:grid;place-items:center;border:1px solid #eee;font-style:normal;font-weight:900;color:#e1306c}.highlight-editor b{font-size:.74rem;max-width:72px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.add-highlight-btn .highlight-ring{background:#f0f0f0}.editable-tabs button{cursor:pointer}.editable-tabs button[data-tab="reels"]{font-size:1.25rem}.editable-grid .post-tile{background:#f3f3f3}.editable-post-tile .post-type-pill{position:absolute;left:7px;bottom:7px;background:rgba(0,0,0,.58);color:#fff;border-radius:999px;padding:4px 7px;font-size:.65rem;font-weight:900;z-index:2}.editable-post-tile:hover .post-type-pill{opacity:0}.add-post-placeholder{border:0;color:#b4b4b4;display:grid;place-items:center;background:linear-gradient(135deg,#f5f5f5,#fbfbfb)!important;cursor:pointer;text-align:center}.add-post-placeholder span{font-size:1.45rem;width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:#fff;box-shadow:0 10px 26px rgba(0,0,0,.08);color:#e1306c}.add-post-placeholder b{font-size:.75rem;margin-top:-18px;color:#777}.add-post-placeholder:hover span{background:var(--accent-gradient);color:#fff}.theme-dark{background:#05060a!important;color:#f7f7fb!important}.theme-dark .ig-appbar,.theme-dark .ig-tabs,.theme-dark .ig-statusbar{background:#05060a!important;border-color:#1e2233!important;color:#f7f7fb}.theme-dark .ig-profile-buttons button{background:#1a1f2e;color:#f7f7fb}.theme-dark .ig-profile-copy a,.theme-dark .editable-profile-copy small{color:#8bb7ff}.theme-dark .ig-count span,.theme-dark .ig-handle-line{color:#a4abc0}.theme-dark .highlight-ring i{background:#111827;color:#fff;border-color:#252b3b}.theme-dark .add-post-placeholder{background:linear-gradient(135deg,#10131f,#161b2b)!important;color:#6f7890}.theme-dark .add-post-placeholder span{background:#202638}.theme-dark .instagram-grid{background:#161b2b}.theme-dark .ig-empty-note{background:#05060a;color:#dbe1f1;border-color:#202638}.upload-progress-shell{display:none;align-items:center;gap:12px;margin:0 0 14px;padding:10px 12px;border-radius:999px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);overflow:hidden}.upload-progress-shell.is-active{display:flex}.upload-progress-shell span{height:9px;flex:1;border-radius:999px;background:var(--accent-gradient);width:0;transition:width .16s}.upload-progress-shell b{font-size:.82rem;color:#d9ddec;white-space:nowrap}.project-tools-card{display:grid;gap:14px;min-width:0}.tool-panel{padding:18px}.tool-panel h3{margin:0 0 8px;font-size:1.05rem}.tool-panel p,.guide-panel li{color:#b3bbcf;line-height:1.55}.guide-panel ol{margin:10px 0 16px;padding-left:20px}.quota-label{display:flex;justify-content:space-between;gap:10px;margin:12px 0 7px;font-size:.82rem;color:#aeb6ca}.quota-label b{color:#fff}.quick-actions-grid{display:grid;gap:10px}.profile-avatar-row{display:flex;align-items:center;gap:14px;padding:12px;border-radius:20px;background:#f7f7f9}.profile-avatar-row p{margin:4px 0 0;color:#6b7280}.profile-avatar-row .instagram-avatar{border:0;position:relative;cursor:pointer}.highlight-preview-big{width:104px;height:104px;border-radius:50%;padding:4px;background:var(--accent-gradient);margin:0 auto 10px;display:grid;place-items:center}.highlight-preview-big span{width:100%;height:100%;border-radius:50%;display:grid;place-items:center;background:#fff;color:#e1306c;font-weight:900;font-size:2rem}.modal-copy{color:#5f6677;line-height:1.6}.modal-sep{border:0;border-top:1px solid #e5e7eb;margin:16px 0}.tour-card{background:#111322;color:#fff}.tour-steps{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:16px}.tour-steps div{padding:15px;border-radius:20px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1)}.tour-steps span{width:34px;height:34px;border-radius:12px;background:var(--accent-gradient);display:grid;place-items:center;font-weight:900;margin-bottom:10px}.tour-steps strong{display:block}.tour-steps p{color:#b7bfd4;line-height:1.55;margin:6px 0 0}.planner-toast{position:fixed;left:50%;bottom:24px;transform:translate(-50%,20px);z-index:110;background:#111827;color:#fff;border:1px solid rgba(255,255,255,.12);box-shadow:0 18px 50px rgba(0,0,0,.28);border-radius:999px;padding:12px 18px;font-weight:850;opacity:0;pointer-events:none;transition:.18s}.planner-toast.is-visible{opacity:1;transform:translate(-50%,0)}.share-studio-v2 .share-preview-wrap{display:grid;place-items:center}.share-phone-stage{width:min(100%,520px)}
@media(max-width:1180px){.studio-grid-v2{grid-template-columns:1fr}.project-tools-card{grid-template-columns:repeat(3,1fr)}.phone-workspace-card{order:1}.project-tools-card{order:2}.studio-actions{margin-top:0}.desktop-scale-controls{display:none}.phone-scale-stage .app-phone-shell{transform:none}.phone-scale-stage{height:auto!important}.app-phone-shell{width:min(430px,100%)} }
@media(max-width:820px){.gram-studio-v2{width:min(100% - 16px,1520px);margin-top:12px}.studio-hero-row,.workspace-head-v2{flex-direction:column;align-items:flex-start}.studio-actions,.studio-actions .btn,.studio-toolbar-v2 .btn{width:100%}.studio-toolbar-v2{align-items:stretch}.toolbar-group{width:100%;justify-content:space-between}.studio-title h1{font-size:2.25rem}.phone-workspace-card{padding:10px;border-radius:22px}.workspace-head-v2 h2{font-size:1.8rem}.workspace-head-v2 p{font-size:.92rem}.post-stat-pill{width:64px;height:64px;min-width:64px}.app-phone-shell{width:100%;padding:7px;border-radius:34px}.editable-phone{border-radius:28px}.editable-phone .ig-profile-header{grid-template-columns:82px repeat(3,1fr);padding:12px 10px 8px;gap:4px}.editable-phone .avatar-lg{width:74px;height:74px}.highlight-editor{gap:10px;padding-left:10px;padding-right:10px}.highlight-editor .highlight-item{min-width:62px}.highlight-editor .highlight-ring{width:58px;height:58px}.highlight-editor b{font-size:.68rem;max-width:62px}.ig-profile-copy,.editable-profile-copy,.readonly-copy{padding-left:12px!important;padding-right:12px!important}.ig-profile-buttons{padding-left:12px!important;padding-right:12px!important}.editable-phone .ig-count strong{font-size:.92rem}.editable-phone .ig-count span{font-size:.64rem}.project-tools-card{grid-template-columns:1fr}.tour-steps{grid-template-columns:1fr}.upload-progress-shell{border-radius:16px;align-items:flex-start;flex-direction:column}.upload-progress-shell span{width:100%;flex:auto}.planner-toast{left:12px;right:12px;transform:translateY(20px);text-align:center}.planner-toast.is-visible{transform:translateY(0)}.instagram-grid{gap:1px}.post-actions{opacity:1}.post-type-pill{display:none}.add-post-placeholder b{display:none}.add-post-placeholder span{width:36px;height:36px}.modal-card{border-radius:20px}.profile-avatar-row{align-items:flex-start}.share-box{width:100%}}
@media(max-width:430px){.gram-studio-v2{width:calc(100% - 10px)}.editable-phone .ig-appbar{padding:0 10px}.editable-phone .ig-app-icons{gap:4px}.editable-phone .ig-profile-header{grid-template-columns:74px repeat(3,1fr)}.editable-phone .avatar-lg{width:68px;height:68px}.highlight-editor .highlight-ring{width:54px;height:54px}.highlight-editor .highlight-item{min-width:56px}.ig-profile-buttons{grid-template-columns:1fr 1fr!important}.ig-profile-buttons button:nth-child(3){display:none}.tool-panel{padding:14px}.studio-toolbar-v2{padding:10px}.phone-workspace-card{padding:6px}.app-phone-shell{padding:5px}}

/* =========================================================
   GramGrid v17: safe mobile reorder, pin icon, clean tiles
   Additive patch. Keeps normal scrolling until Reorder mode is enabled.
========================================================= */
.editable-grid .post-tile{
  touch-action: pan-y;
  -webkit-user-select:none;
  user-select:none;
}
.editable-grid .post-tile.can-reorder{
  touch-action:none;
  cursor:grab;
}
.editable-grid .post-tile.can-reorder:active,
.editable-grid .post-tile.dragging{
  cursor:grabbing;
}
.editable-phone.is-reorder-mode .editable-grid .post-tile.can-reorder{
  outline:1px solid rgba(225,48,108,.34);
  outline-offset:-1px;
}
.reorder-hint{
  display:none;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:8px 10px;
  background:linear-gradient(135deg,rgba(255,122,26,.14),rgba(225,48,108,.14),rgba(108,92,231,.14));
  border-top:1px solid rgba(225,48,108,.20);
  border-bottom:1px solid rgba(225,48,108,.18);
  color:inherit;
  font-size:.72rem;
  font-weight:850;
}
.reorder-hint button{
  border:0;
  border-radius:999px;
  padding:7px 12px;
  background:linear-gradient(135deg,#ff7a1a,#e1306c,#6c5ce7);
  color:#fff;
  font-weight:950;
  box-shadow:0 8px 18px rgba(225,48,108,.22);
}
.post-actions-v17{
  left:6px!important;
  right:6px!important;
  top:6px!important;
  justify-content:space-between!important;
  align-items:center!important;
  gap:4px!important;
  z-index:8!important;
}
.post-actions-v17 .icon-btn{
  min-width:30px;
  height:28px;
  padding:0 8px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:4px;
  border-radius:999px!important;
  color:#fff!important;
  background:rgba(7,10,20,.76)!important;
  border:1px solid rgba(255,255,255,.18)!important;
  box-shadow:0 8px 20px rgba(0,0,0,.22)!important;
  backdrop-filter:blur(8px);
  font-weight:900!important;
  font-size:.68rem!important;
  line-height:1!important;
}
.post-actions-v17 .icon-btn svg,
.video-badge svg,
.pin-badge svg{
  width:15px;
  height:15px;
  display:block;
}
.post-actions-v17 .move-btn{
  width:32px!important;
  padding:0!important;
  color:#fff!important;
  background:linear-gradient(135deg,rgba(255,122,26,.92),rgba(225,48,108,.92),rgba(108,92,231,.92))!important;
}
.post-actions-v17 .pin-btn{
  width:32px!important;
  padding:0!important;
}
.post-actions-v17 .pin-btn.is-active{
  background:linear-gradient(135deg,#feda75,#e1306c,#6c5ce7)!important;
  color:#fff!important;
}
.post-actions-v17 .danger-mini{
  background:rgba(220,38,38,.78)!important;
}
.post-tile.is-pinned:after{
  content:"";
  position:absolute;
  inset:0;
  border:2px solid rgba(225,48,108,.55);
  pointer-events:none;
  z-index:3;
}
.pin-badge{
  position:absolute;
  left:7px;
  top:40px;
  z-index:7;
  width:26px;
  height:26px;
  border-radius:999px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,#feda75,#e1306c,#6c5ce7);
  color:#fff;
  box-shadow:0 8px 18px rgba(0,0,0,.28);
}
.tile-video{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  background:#111827;
}
.video-badge{
  position:absolute!important;
  right:7px!important;
  top:7px!important;
  z-index:6!important;
  width:26px!important;
  height:26px!important;
  padding:0!important;
  border-radius:7px!important;
  display:grid!important;
  place-items:center!important;
  background:rgba(255,255,255,.92)!important;
  color:#111!important;
  box-shadow:0 6px 18px rgba(0,0,0,.25)!important;
  font-size:0!important;
}
.video-play{
  display:none!important;
}
.add-post-placeholder{
  background:linear-gradient(135deg,#eef2ff,#f8fafc)!important;
  color:#667085!important;
}
.add-post-placeholder .add-plus,
.add-post-placeholder span{
  width:44px!important;
  height:44px!important;
  border-radius:50%!important;
  display:grid!important;
  place-items:center!important;
  background:linear-gradient(135deg,#ff7a1a,#e1306c,#6c5ce7)!important;
  color:#fff!important;
  box-shadow:0 10px 24px rgba(225,48,108,.28)!important;
  font-size:1.55rem!important;
  line-height:1!important;
}
.add-post-placeholder b{
  display:block!important;
  margin-top:54px!important;
  color:#667085!important;
  font-size:.72rem!important;
  font-weight:900!important;
}
.theme-dark .add-post-placeholder{
  background:linear-gradient(135deg,#101625,#171d2f)!important;
  color:#dbe4f5!important;
}
.theme-dark .add-post-placeholder b{
  color:#dbe4f5!important;
}
.theme-dark .add-post-placeholder .add-plus,
.theme-dark .add-post-placeholder span{
  background:linear-gradient(135deg,#ff7a1a,#e1306c,#6c5ce7)!important;
  color:#fff!important;
}
.theme-dark .ig-tabs button,
.theme-dark .editable-tabs button{
  color:#cfd6e9!important;
}
.theme-dark .ig-tabs button.active,
.theme-dark .editable-tabs button.active{
  color:#fff!important;
}
.theme-dark #bioPreview{
  color:#e8edf8!important;
  white-space:pre-line!important;
}
#bioPreview{
  white-space:pre-line!important;
}
@media(max-width:820px){
  .post-actions-v17{
    opacity:1!important;
    top:5px!important;
    left:5px!important;
    right:5px!important;
  }
  .post-actions-v17 .icon-btn{
    height:27px;
    min-width:28px;
    padding:0 7px!important;
    font-size:.62rem!important;
  }
  .post-actions-v17 .move-btn,
  .post-actions-v17 .pin-btn{
    width:29px!important;
  }
  .post-actions-v17 .icon-btn svg,
  .video-badge svg,
  .pin-badge svg{
    width:14px;
    height:14px;
  }
  .reorder-hint{
    position:sticky;
    top:0;
    z-index:12;
    padding:8px 9px;
    font-size:.67rem;
  }
  .reorder-hint button{
    padding:7px 10px;
  }
  .pin-badge{
    width:24px;
    height:24px;
    top:36px;
    left:6px;
  }
  .add-post-placeholder .add-plus,
  .add-post-placeholder span{
    width:38px!important;
    height:38px!important;
    font-size:1.35rem!important;
  }
  .add-post-placeholder b{
    margin-top:48px!important;
    font-size:.66rem!important;
  }
}
.add-post-placeholder{
  display:flex!important;
  flex-direction:column!important;
  align-items:center!important;
  justify-content:center!important;
  gap:6px!important;
}
.add-post-placeholder b{margin-top:0!important;}
@media(max-width:820px){.add-post-placeholder b{margin-top:0!important;}}

/* =========================================================
   GramGrid app UX patch v12
   Mobile planner = app-like screen + fixed bottom dock.
   Keeps phone preview interactive while removing the need to
   scroll below it on mobile.
========================================================= */

/* Better share/copy actions everywhere */
.btn-copy-link,
button[data-copy],
.btn[data-copy],
button[data-copy-target],
.btn[data-copy-target] {
  background: linear-gradient(135deg, #ff7a1a 0%, #e1306c 48%, #6c5ce7 100%) !important;
  color: #fff !important;
  border: 0 !important;
  font-weight: 900 !important;
  box-shadow: 0 12px 30px rgba(225, 48, 108, .34) !important;
  text-shadow: 0 1px 1px rgba(0,0,0,.25);
}
.btn-copy-link:hover,
button[data-copy]:hover,
.btn[data-copy]:hover,
button[data-copy-target]:hover,
.btn[data-copy-target]:hover {
  transform: translateY(-1px);
  filter: brightness(1.06);
  box-shadow: 0 16px 38px rgba(225, 48, 108, .44) !important;
}
.btn-copy-link.is-copied,
button[data-copy-target].is-copied {
  background: linear-gradient(135deg, #14b86f 0%, #22c55e 100%) !important;
}

/* Disable share link must be readable on any modal/card background */
.btn-share-disable,
button.btn-share-disable,
.instagram-modal .btn-share-disable,
#toggleShare.btn-share-disable {
  background: linear-gradient(135deg, #ff416c 0%, #ff4b2b 100%) !important;
  border: 0 !important;
  color: #fff !important;
  font-weight: 950 !important;
  box-shadow: 0 14px 34px rgba(255, 65, 108, .34) !important;
  text-shadow: 0 1px 1px rgba(0,0,0,.34);
}
.btn-share-disable:hover,
#toggleShare.btn-share-disable:hover {
  filter: brightness(1.06);
  color: #fff !important;
  box-shadow: 0 18px 42px rgba(255, 65, 108, .44) !important;
}

.share-box {
  align-items: stretch;
}
.share-box .input,
.share-box input {
  min-height: 48px;
}
.share-box .btn-copy-link {
  min-width: 118px;
}

/* Mobile action dock is hidden on desktop */
.planner-mobile-dock {
  display: none;
}

@media (max-width: 820px) {
  html, body {
    overflow-x: hidden;
  }

  body.app-page {
    padding-bottom: calc(86px + env(safe-area-inset-bottom));
  }

  .planner-page.gram-studio-v2 {
    width: min(100% - 12px, 1380px);
    margin-top: 8px;
  }

  .gram-studio-v2 .studio-hero-row {
    gap: 8px;
    margin-bottom: 8px;
  }

  .gram-studio-v2 .studio-title h1 {
    font-size: clamp(1.65rem, 8vw, 2.4rem);
    margin-bottom: 4px;
  }

  .gram-studio-v2 .studio-title p,
  .gram-studio-v2 .top-actions,
  .gram-studio-v2 .studio-toolbar-v2,
  .gram-studio-v2 .project-tools-card,
  .gram-studio-v2 .workspace-head-v2 {
    display: none !important;
  }

  .gram-studio-v2 .studio-grid-v2 {
    display: block !important;
    grid-template-columns: 1fr !important;
    gap: 0 !important;
  }

  .gram-studio-v2 .phone-workspace-card {
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  .gram-studio-v2 .phone-scale-stage {
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    display: grid !important;
    place-items: center !important;
    overflow: visible !important;
    padding: 0 0 8px !important;
  }

  .gram-studio-v2 .instagram-preview-shell.app-phone-shell {
    width: min(100%, 390px) !important;
    max-width: calc(100vw - 16px) !important;
    transform: none !important;
    margin: 0 auto !important;
    padding: 8px !important;
    border-radius: 34px !important;
  }

  .gram-studio-v2 .instagram-preview.editable-phone {
    height: min(690px, calc(100svh - 148px)) !important;
    min-height: 520px !important;
    max-height: calc(100svh - 148px) !important;
    overflow-y: auto !important;
    overscroll-behavior: contain !important;
    -webkit-overflow-scrolling: touch;
    border-radius: 27px !important;
  }

  /* Keep the phone usable as the main app screen */
  .gram-studio-v2 .ig-statusbar,
  .gram-studio-v2 .ig-appbar {
    position: sticky;
    top: 0;
    z-index: 7;
  }

  .gram-studio-v2 .ig-statusbar {
    background: inherit;
  }

  .gram-studio-v2 .ig-appbar {
    background: inherit;
    backdrop-filter: blur(12px);
  }

  .gram-studio-v2 .editable-grid {
    min-height: 310px;
  }

  .planner-mobile-dock {
    position: fixed;
    left: 10px;
    right: 10px;
    bottom: calc(10px + env(safe-area-inset-bottom));
    z-index: 90;
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 7px;
    padding: 9px;
    border-radius: 24px;
    background: rgba(9, 10, 22, .86);
    border: 1px solid rgba(255,255,255,.14);
    box-shadow: 0 18px 50px rgba(0,0,0,.38);
    backdrop-filter: blur(18px);
  }

  .mobile-dock-btn {
    border: 0;
    border-radius: 18px;
    min-height: 58px;
    padding: 7px 4px;
    background: rgba(255,255,255,.08);
    color: #fff;
    display: grid;
    place-items: center;
    gap: 2px;
    font-weight: 850;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.06);
  }

  .mobile-dock-btn span {
    width: 24px;
    height: 24px;
    border-radius: 10px;
    display: grid;
    place-items: center;
    background: rgba(255,255,255,.08);
    font-size: 1rem;
    line-height: 1;
  }

  .mobile-dock-btn b {
    font-size: .68rem;
    letter-spacing: -.02em;
  }

  .mobile-dock-btn.primary {
    background: var(--accent-gradient) !important;
    box-shadow: 0 12px 28px rgba(225,48,108,.32);
  }

  .mobile-dock-btn.primary span {
    background: rgba(255,255,255,.18);
  }

  /* Mobile modals behave like bottom sheets */
  .modal {
    align-items: flex-end !important;
    padding: 10px !important;
  }

  .modal-card {
    width: 100% !important;
    max-height: min(84svh, 760px) !important;
    border-radius: 26px 26px 18px 18px !important;
    animation: gramgridSheetUp .22s ease both;
  }

  .modal-head:before {
    content: "";
    position: absolute;
    left: 50%;
    top: 8px;
    transform: translateX(-50%);
    width: 44px;
    height: 4px;
    border-radius: 999px;
    background: rgba(0,0,0,.18);
  }

  .modal-head {
    position: relative;
    padding-top: 14px;
  }

  .instagram-modal .modal-head:before {
    background: rgba(17,24,39,.18);
  }

  @keyframes gramgridSheetUp {
    from { transform: translateY(22px); opacity: .78; }
    to { transform: translateY(0); opacity: 1; }
  }

  .share-box {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }

  .share-box .btn-copy-link {
    width: 100%;
  }
}

@media (max-width: 380px) {
  .planner-mobile-dock {
    left: 6px;
    right: 6px;
    gap: 5px;
    padding: 7px;
    border-radius: 20px;
  }
  .mobile-dock-btn {
    min-height: 54px;
    border-radius: 15px;
  }
  .mobile-dock-btn b {
    font-size: .62rem;
  }
  .gram-studio-v2 .instagram-preview.editable-phone {
    height: calc(100svh - 140px) !important;
    min-height: 490px !important;
  }
}

/* =========================================================
   GramGrid v13 responsive refinement
   Fixes:
   - Desktop phone was too narrow/tall after mobile UX patch.
   - Desktop grid should behave like Instagram: fixed phone height + internal scroll.
   - Mobile should feel like an app screen with more viewport height.
========================================================= */

/* Desktop / tablet workspace: keep phone proportional, not stretched by content */
@media (min-width: 821px) {
  .gram-studio-v2 .studio-grid-v2 {
    grid-template-columns: minmax(0, 1fr) 340px;
    align-items: start;
  }

  .gram-studio-v2 .phone-workspace-card {
    overflow: visible !important;
  }

  .gram-studio-v2 .phone-scale-stage {
    --phone-scale: 1;
    min-height: 0 !important;
    display: grid !important;
    place-items: start center !important;
    padding-bottom: 8px !important;
    overflow: visible !important;
  }

  .gram-studio-v2 .phone-scale-stage .app-phone-shell {
    transform: scale(var(--phone-scale)) !important;
    transform-origin: top center !important;
  }

  .gram-studio-v2 .instagram-preview-shell.app-phone-shell {
    width: 440px !important;
    max-width: 100% !important;
    padding: 11px !important;
    border-radius: 48px !important;
  }

  .gram-studio-v2 .instagram-preview.editable-phone {
    height: 812px !important;
    min-height: 0 !important;
    max-height: 812px !important;
    overflow-y: auto !important;
    overscroll-behavior: contain !important;
    -webkit-overflow-scrolling: touch;
    border-radius: 38px !important;
  }

  /* Keep profile area compact so 3 grid rows are visible before internal scroll */
  .gram-studio-v2 .editable-phone .ig-profile-header {
    grid-template-columns: 92px repeat(3,1fr) !important;
    padding: 12px 16px 7px !important;
  }

  .gram-studio-v2 .editable-phone .avatar-lg {
    width: 84px !important;
    height: 84px !important;
  }

  .gram-studio-v2 .editable-phone .ig-profile-copy {
    padding: 0 16px 8px !important;
    font-size: .86rem !important;
    line-height: 1.32 !important;
  }

  .gram-studio-v2 .editable-phone .ig-profile-buttons {
    padding: 0 16px 10px !important;
  }

  .gram-studio-v2 .highlight-editor {
    padding: 0 16px 10px !important;
    gap: 13px !important;
  }

  .gram-studio-v2 .highlight-editor .highlight-item {
    min-width: 66px !important;
  }

  .gram-studio-v2 .highlight-editor .highlight-ring {
    width: 62px !important;
    height: 62px !important;
  }

  .gram-studio-v2 .highlight-editor b {
    font-size: .71rem !important;
    max-width: 68px !important;
  }

  .gram-studio-v2 .ig-tabs {
    height: 42px !important;
  }

  .gram-studio-v2 .instagram-grid {
    min-height: 0 !important;
  }
}

/* Medium desktop: keep it fitting inside narrower screens without becoming a thin phone */
@media (min-width: 821px) and (max-width: 1120px) {
  .gram-studio-v2 .studio-grid-v2 {
    grid-template-columns: 1fr !important;
  }

  .gram-studio-v2 .project-tools-card {
    grid-template-columns: repeat(2, minmax(0,1fr));
    display: grid;
  }

  .gram-studio-v2 .instagram-preview-shell.app-phone-shell {
    width: 430px !important;
  }
}

/* Mobile app-like composer */
@media (max-width: 820px) {
  html, body {
    overflow-x: hidden !important;
  }

  body.app-page {
    padding-bottom: calc(66px + env(safe-area-inset-bottom)) !important;
  }

  .gram-studio-v2 .studio-hero-row {
    margin-bottom: 4px !important;
  }

  .gram-studio-v2 .phone-scale-stage {
    padding: 0 0 4px !important;
    width: 100% !important;
    overflow: visible !important;
  }

  .gram-studio-v2 .instagram-preview-shell.app-phone-shell {
    width: min(100%, 420px) !important;
    max-width: calc(100vw - 10px) !important;
    padding: 6px !important;
    margin: 0 auto !important;
    border-radius: 31px !important;
    transform: none !important;
  }

  .gram-studio-v2 .instagram-preview.editable-phone {
    height: calc(100svh - 92px) !important;
    min-height: 560px !important;
    max-height: calc(100svh - 92px) !important;
    overflow-y: auto !important;
    overscroll-behavior: contain !important;
    -webkit-overflow-scrolling: touch;
    border-radius: 26px !important;
  }

  /* More app-like, less wasted vertical space */
  .gram-studio-v2 .editable-phone .ig-statusbar {
    height: 24px !important;
    padding: 0 14px !important;
    font-size: .68rem !important;
  }

  .gram-studio-v2 .editable-phone .ig-appbar {
    height: 43px !important;
    padding: 0 12px !important;
  }

  .gram-studio-v2 .editable-phone .ig-profile-header {
    grid-template-columns: 78px repeat(3, 1fr) !important;
    padding: 11px 12px 6px !important;
    gap: 5px !important;
  }

  .gram-studio-v2 .editable-phone .avatar-lg {
    width: 70px !important;
    height: 70px !important;
  }

  .gram-studio-v2 .ig-count strong {
    font-size: .92rem !important;
  }

  .gram-studio-v2 .ig-count span {
    font-size: .66rem !important;
  }

  .gram-studio-v2 .editable-phone .ig-profile-copy {
    padding: 0 12px 7px !important;
    font-size: .8rem !important;
    line-height: 1.28 !important;
  }

  .gram-studio-v2 .editable-phone .ig-profile-copy h2 {
    font-size: .86rem !important;
  }

  .gram-studio-v2 .editable-phone .ig-profile-buttons {
    padding: 0 12px 9px !important;
    gap: 5px !important;
  }

  .gram-studio-v2 .editable-phone .ig-profile-buttons button {
    padding: 7px 5px !important;
    font-size: .76rem !important;
  }

  .gram-studio-v2 .highlight-editor {
    padding: 0 12px 9px !important;
    gap: 10px !important;
  }

  .gram-studio-v2 .highlight-editor .highlight-item {
    min-width: 60px !important;
  }

  .gram-studio-v2 .highlight-editor .highlight-ring {
    width: 56px !important;
    height: 56px !important;
  }

  .gram-studio-v2 .highlight-editor b {
    font-size: .68rem !important;
    max-width: 62px !important;
  }

  .gram-studio-v2 .ig-tabs {
    height: 39px !important;
  }

  .planner-mobile-dock {
    left: 6px !important;
    right: 6px !important;
    bottom: calc(2px + env(safe-area-inset-bottom)) !important;
    gap: 5px !important;
    padding: 6px !important;
    border-radius: 20px !important;
  }

  .mobile-dock-btn {
    min-height: 50px !important;
    border-radius: 15px !important;
    padding: 5px 3px !important;
  }

  .mobile-dock-btn span {
    width: 22px !important;
    height: 22px !important;
    border-radius: 8px !important;
  }

  .mobile-dock-btn b {
    font-size: .62rem !important;
  }
}

/* Very small phones: keep dock compact and avoid horizontal pressure */
@media (max-width: 380px) {
  .gram-studio-v2 .instagram-preview-shell.app-phone-shell {
    max-width: calc(100vw - 6px) !important;
    padding: 5px !important;
  }

  .gram-studio-v2 .instagram-preview.editable-phone {
    height: calc(100svh - 86px) !important;
    min-height: 520px !important;
    max-height: calc(100svh - 86px) !important;
  }

  .planner-mobile-dock {
    left: 4px !important;
    right: 4px !important;
    padding: 5px !important;
  }

  .mobile-dock-btn {
    min-height: 48px !important;
  }
}

/* =========================================================
   GramGrid v15 planner UX fixes
   - Mobile phone menu with quota/guide
   - Dark bio readability + preserved line breaks
   - Clear add-post plus slots
   - Instagram-like reel corner icon
   - Touch reordering feedback
   - Password eye controls
========================================================= */
#bioPreview,
.ig-profile-copy #bioPreview,
.readonly-copy #bioPreview {
  white-space: pre-line !important;
}
.theme-dark #bioPreview,
.theme-dark .ig-profile-copy p:not(.ig-handle-line),
.theme-dark .readonly-copy p:not(.ig-handle-line) {
  color: #dbe4f6 !important;
}
.theme-dark .ig-tabs button,
.theme-dark .editable-tabs button {
  color: #b8c0d6 !important;
}
.theme-dark .ig-tabs button.active,
.theme-dark .editable-tabs button.active {
  color: #ffffff !important;
}
.theme-dark .highlight-editor b {
  color: #dce4f7 !important;
}
.add-post-placeholder {
  background: linear-gradient(135deg, rgba(148,163,184,.16), rgba(30,41,59,.12)) !important;
  border: 1px dashed rgba(148,163,184,.28) !important;
  color: #7b8497 !important;
}
.add-post-placeholder span {
  background: rgba(15,23,42,.08) !important;
  border: 2px solid rgba(148,163,184,.22) !important;
  box-shadow: none !important;
  color: #e1306c !important;
}
.add-post-placeholder b {
  color: #7c8799 !important;
  font-weight: 900 !important;
}
.theme-dark .add-post-placeholder {
  background: linear-gradient(135deg, rgba(15,23,42,.88), rgba(20,26,42,.95)) !important;
  border-color: rgba(148,163,184,.18) !important;
}
.theme-dark .add-post-placeholder span {
  background: rgba(255,255,255,.055) !important;
  border-color: rgba(255,255,255,.18) !important;
  color: #ffffff !important;
}
.theme-dark .add-post-placeholder b {
  color: #c8d0e3 !important;
}
.post-tile video {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  background: #111827 !important;
}
.video-play {
  display: none !important;
}
.video-badge {
  display: none !important;
}
.video-corner-badge {
  position: absolute;
  right: 8px;
  top: 8px;
  z-index: 4;
  width: 24px;
  height: 24px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  background: rgba(0,0,0,.38);
  color: #fff;
  font-size: .78rem;
  line-height: 1;
  text-shadow: 0 1px 3px rgba(0,0,0,.4);
  backdrop-filter: blur(6px);
}
.pin-badge {
  position: absolute;
  left: 8px;
  top: 8px;
  z-index: 4;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: rgba(0,0,0,.55);
  color: #fff;
  font-size: .78rem;
  backdrop-filter: blur(6px);
}
.post-tile.is-pinned {
  outline: 2px solid rgba(254, 218, 117, .55);
  outline-offset: -2px;
}
.is-touch-reordering .editable-post-tile {
  touch-action: none;
}
.is-touch-reordering .editable-post-tile.dragging {
  opacity: .72;
  transform: scale(.97);
  z-index: 10;
}
.highlight-upload-target {
  border: 0;
  cursor: pointer;
}
.center-help {
  text-align: center;
  margin: -2px 0 2px !important;
}
.phone-menu-modal {
  align-items: center !important;
  justify-content: center !important;
}
.phone-menu-card {
  background: radial-gradient(circle at 18% 0%, rgba(225,48,108,.22), transparent 32%), linear-gradient(180deg, #121523 0%, #080a12 100%) !important;
  color: #fff !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  box-shadow: 0 30px 90px rgba(0,0,0,.5) !important;
}
.phone-menu-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 16px;
}
.phone-menu-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}
.phone-menu-brand strong,
.phone-menu-brand span {
  display: block;
  max-width: 220px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.phone-menu-brand span {
  color: #aeb7ce;
  font-size: .86rem;
  margin-top: 2px;
}
.phone-menu-links {
  display: grid;
  gap: 9px;
  margin-bottom: 16px;
}
.phone-menu-links a,
.phone-menu-links button {
  width: 100%;
  border: 1px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.065);
  color: #fff;
  border-radius: 16px;
  padding: 13px 14px;
  text-align: left;
  font-weight: 900;
}
.phone-menu-links a:first-child,
.phone-menu-links button:nth-child(4) {
  background: var(--accent-gradient);
  border: 0;
}
.phone-menu-quota,
.phone-menu-guide {
  padding: 14px;
  border-radius: 20px;
  background: rgba(255,255,255,.055);
  border: 1px solid rgba(255,255,255,.08);
  margin-top: 12px;
}
.phone-menu-quota h3,
.phone-menu-guide h3 {
  margin: 0 0 8px;
}
.phone-menu-quota p,
.phone-menu-guide li {
  color: #b8c0d6;
  line-height: 1.5;
}
.phone-menu-guide ol {
  margin: 8px 0 0;
  padding-left: 19px;
}
.password-wrap {
  position: relative;
}
.password-wrap .input {
  padding-right: 52px !important;
}
.password-eye {
  position: absolute;
  right: 9px;
  top: 50%;
  transform: translateY(-50%);
  width: 38px;
  height: 38px;
  border: 0;
  border-radius: 12px;
  background: rgba(255,255,255,.08);
  color: #fff;
  display: grid;
  place-items: center;
  font-size: 1rem;
}
.auth-card .password-eye {
  background: rgba(15,23,42,.08);
  color: #111827;
}
@media (max-width: 820px) {
  .phone-menu-modal {
    padding: 0 !important;
    align-items: stretch !important;
  }
  .phone-menu-modal .modal-card {
    width: 100vw !important;
    height: 100svh !important;
    max-height: 100svh !important;
    border-radius: 0 !important;
    overflow: auto !important;
    padding: max(18px, env(safe-area-inset-top)) 16px max(22px, env(safe-area-inset-bottom)) !important;
    animation: none !important;
  }
  .phone-menu-modal .modal-head:before,
  .phone-menu-modal .phone-menu-head:before {
    display: none !important;
  }
  .planner-mobile-dock {
    grid-template-columns: repeat(5, 1fr) !important;
  }
  .gram-studio-v2 .instagram-preview.editable-phone {
    height: calc(100svh - 78px) !important;
    max-height: calc(100svh - 78px) !important;
    min-height: 600px !important;
  }
  .add-post-placeholder span {
    width: 38px !important;
    height: 38px !important;
  }
  .add-post-placeholder b {
    display: block !important;
    margin-top: -12px !important;
    font-size: .68rem !important;
  }
}
@media (max-width: 380px) {
  .gram-studio-v2 .instagram-preview.editable-phone {
    height: calc(100svh - 74px) !important;
    max-height: calc(100svh - 74px) !important;
    min-height: 540px !important;
  }
}


/* =========================================================
   GramGrid v16 mobile chrome + scrollbar cleanup
   - Hide external site/header/title on mobile project editor
   - Keep all navigation inside the phone hamburger menu
   - Hide ugly internal scrollbars while keeping scrolling
========================================================= */

/* Hide inner preview scrollbars everywhere, but keep scroll working */
.instagram-preview.editable-phone,
.instagram-preview,
.phone-scale-stage,
.instagram-preview-shell.app-phone-shell,
.public-shell {
  -ms-overflow-style: none !important;
  scrollbar-width: none !important;
}
.instagram-preview.editable-phone::-webkit-scrollbar,
.instagram-preview::-webkit-scrollbar,
.phone-scale-stage::-webkit-scrollbar,
.instagram-preview-shell.app-phone-shell::-webkit-scrollbar,
.public-shell::-webkit-scrollbar {
  width: 0 !important;
  height: 0 !important;
  display: none !important;
  background: transparent !important;
}

@media (max-width: 820px) {
  /* Project editor becomes app-like: no external website header/title. */
  body.project-editor-page .site-header,
  body.project-editor-page .studio-hero-row,
  body.project-editor-page .site-footer {
    display: none !important;
  }

  body.project-editor-page main {
    padding-top: 0 !important;
  }

  body.project-editor-page .planner-page.gram-studio-v2 {
    margin-top: 0 !important;
    width: 100% !important;
  }

  body.project-editor-page .phone-workspace-card {
    border-radius: 0 !important;
  }

  body.project-editor-page .phone-scale-stage {
    padding-top: 2px !important;
  }

  body.project-editor-page .instagram-preview-shell.app-phone-shell {
    max-width: calc(100vw - 8px) !important;
  }

  /* With external header removed, give the phone more height. */
  body.project-editor-page .instagram-preview.editable-phone {
    height: calc(100svh - 66px - env(safe-area-inset-bottom)) !important;
    max-height: calc(100svh - 66px - env(safe-area-inset-bottom)) !important;
    min-height: 620px !important;
  }

  /* Client preview links should also feel like a real phone preview on mobile. */
  body.public-preview-page .site-header,
  body.public-preview-page .share-top,
  body.public-preview-page .site-footer {
    display: none !important;
  }

  body.public-preview-page .planner-page.gram-studio-v2 {
    margin-top: 0 !important;
    width: 100% !important;
  }

  body.public-preview-page .share-preview-wrap {
    padding-top: 2px !important;
  }

  body.public-preview-page .instagram-preview.editable-phone {
    height: calc(100svh - 10px) !important;
    max-height: calc(100svh - 10px) !important;
    min-height: 620px !important;
  }

  /* Avoid any accidental page-width overflow from phone borders/shadows. */
  body.project-editor-page,
  body.public-preview-page {
    overflow-x: hidden !important;
  }
}

@media (max-width: 380px) {
  body.project-editor-page .instagram-preview.editable-phone {
    height: calc(100svh - 62px - env(safe-area-inset-bottom)) !important;
    max-height: calc(100svh - 62px - env(safe-area-inset-bottom)) !important;
    min-height: 560px !important;
  }
  body.public-preview-page .instagram-preview.editable-phone {
    height: calc(100svh - 8px) !important;
    max-height: calc(100svh - 8px) !important;
    min-height: 560px !important;
  }
}



/* =========================================================
   GramGrid v18 restore mobile app mode after v17 reorder patch
   Restores fullscreen phone + bottom dock, keeps safe reorder.
========================================================= */
@media (max-width: 820px) {
  body.project-editor-page .site-header,
  body.project-editor-page .studio-hero-row,
  body.project-editor-page .site-footer {
    display: none !important;
  }
  body.project-editor-page main {
    min-height: 100svh !important;
    overflow-x: hidden !important;
  }
  body.project-editor-page .planner-page.gram-studio-v2 {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 0 calc(70px + env(safe-area-inset-bottom)) !important;
  }
  body.project-editor-page .studio-grid-v2 {
    display: block !important;
  }
  body.project-editor-page .project-tools-card,
  body.project-editor-page .workspace-head-v2 {
    display: none !important;
  }
  body.project-editor-page .phone-workspace-card {
    width: 100% !important;
    min-height: 100svh !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    padding: max(6px, env(safe-area-inset-top)) 6px 0 !important;
  }
  body.project-editor-page .phone-scale-stage {
    height: auto !important;
    display: grid !important;
    place-items: start center !important;
    overflow: visible !important;
  }
  body.project-editor-page .instagram-preview-shell.app-phone-shell {
    width: min(100vw - 12px, 430px) !important;
    max-width: calc(100vw - 12px) !important;
    min-height: calc(100svh - 74px - env(safe-area-inset-bottom)) !important;
    height: calc(100svh - 74px - env(safe-area-inset-bottom)) !important;
    border-radius: 30px !important;
    padding: 5px !important;
    transform: none !important;
  }
  body.project-editor-page .instagram-preview.editable-phone {
    height: 100% !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
    border-radius: 25px !important;
  }
  body.project-editor-page .instagram-preview.editable-phone::-webkit-scrollbar {
    display: none !important;
    width: 0 !important;
    height: 0 !important;
  }
  .planner-mobile-dock {
    display: grid !important;
    position: fixed !important;
    left: 8px !important;
    right: 8px !important;
    bottom: calc(4px + env(safe-area-inset-bottom)) !important;
    z-index: 120 !important;
    grid-template-columns: repeat(5, 1fr) !important;
    gap: 6px !important;
    padding: 8px !important;
    border-radius: 22px !important;
    background: rgba(7, 8, 17, .88) !important;
    border: 1px solid rgba(255,255,255,.14) !important;
    box-shadow: 0 18px 50px rgba(0,0,0,.42) !important;
    backdrop-filter: blur(18px) !important;
  }
  .mobile-dock-btn {
    min-width: 0 !important;
    border: 0 !important;
    border-radius: 16px !important;
    background: rgba(255,255,255,.07) !important;
    color: #fff !important;
    padding: 8px 3px 7px !important;
    display: grid !important;
    justify-items: center !important;
    gap: 3px !important;
    font-weight: 900 !important;
  }
  .mobile-dock-btn span { font-size: 1.05rem !important; line-height: 1 !important; }
  .mobile-dock-btn b { font-size: .62rem !important; line-height: 1 !important; }
  .mobile-dock-btn.primary { background: var(--accent-gradient) !important; }
}
@media (min-width: 821px) {
  .planner-mobile-dock { display: none !important; }
}
/* keep scrollbars invisible in phone on desktop too */
.instagram-preview.editable-phone,
.instagram-preview.readonly-phone {
  scrollbar-width: none !important;
}
.instagram-preview.editable-phone::-webkit-scrollbar,
.instagram-preview.readonly-phone::-webkit-scrollbar {
  display: none !important;
  width: 0 !important;
}
